.dual-range-input {
  --dri-height: 1.5rem;
  --dri-thumb-width: 1.25rem;
  --dri-thumb-height: 1.25rem;
  --dri-thumb-color: #ddd;
  --dri-thumb-hover-color: #a8d5ff;
  --dri-thumb-active-color: #4eaaff;
  --dri-thumb-border-color: rgba(0, 0, 0, 0.1);
  --dri-thumb-border-hover-color: var(--dri-thumb-border-color);
  --dri-thumb-border-active-color: var(--dri-thumb-border-color);
  --dri-thumb-border-radius: 1rem;
  --dri-thumb-border-width: 1px;
  --dri-track-height: 0.25rem;
  --dri-track-border-radius: 1rem;
  --dri-track-color: #ccc;
  --dri-track-filled-color: #0084ff;
  --dri-track-filled-gradient-mid-color: var(--dri-track-filled-color);
  --dri-track-filled-gradient-end-color: var(--dri-track-filled-color);
  display: flex;
  height: var(--dri-height);
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
  padding-inline-end: calc(var(--dri-thumb-width) * 2);
}

.dual-range-input:has(input:focus-visible) {
  outline: 2px solid var(--dri-thumb-active-color);
  outline-offset: 4px;
  border-radius: 2px;
}

.dual-range-input input {
  -webkit-tap-highlight-color: transparent;
  -webkit-appearance: none;
  appearance: none;
  background: none;
  border-radius: 0;
  flex-basis: calc(50% + var(--dri-thumb-width));
  flex-shrink: 0;
  font-size: inherit;
  height: 100%;
  margin: 0;
  min-width: var(--dri-thumb-width);
  outline: none;
}

.dual-range-input input::-moz-range-track {
  background-color: var(--dri-track-color);
  background-repeat: no-repeat;
  box-sizing: border-box;
  height: var(--dri-track-height);
}

.dual-range-input input:first-child::-moz-range-track {
  border-start-start-radius: var(--dri-track-border-radius);
  border-end-start-radius: var(--dri-track-border-radius);
  background-image: linear-gradient(to right, var(--dri-track-color) var(--dri-gradient-position), var(--dri-track-filled-color) var(--dri-gradient-position), var(--dri-track-filled-gradient-mid-color));
}

[dir=rtl] .dual-range-input input:first-child::-moz-range-track {
  background-image: linear-gradient(to left, var(--dri-track-color) var(--dri-gradient-position), var(--dri-track-filled-color) var(--dri-gradient-position), var(--dri-track-filled-gradient-mid-color));
}

.dual-range-input input:last-child::-moz-range-track {
  border-start-end-radius: var(--dri-track-border-radius);
  border-end-end-radius: var(--dri-track-border-radius);
  background-image: linear-gradient(to right, var(--dri-track-filled-gradient-mid-color), var(--dri-track-filled-gradient-end-color) var(--dri-gradient-position), var(--dri-track-color) var(--dri-gradient-position));
}

[dir=rtl] .dual-range-input input:last-child::-moz-range-track {
  background-image: linear-gradient(to left, var(--dri-track-filled-gradient-mid-color), var(--dri-track-filled-gradient-end-color) var(--dri-gradient-position), var(--dri-track-color) var(--dri-gradient-position));
}

.dual-range-input input::-moz-range-thumb {
  -webkit-appearance: none;
  appearance: none;
  background-color: var(--dri-thumb-color);
  border-radius: var(--dri-thumb-border-radius);
  border: var(--dri-thumb-border-width) solid var(--dri-thumb-border-color);
  box-shadow: none;
  box-sizing: border-box;
  height: var(--dri-thumb-height);
  width: var(--dri-thumb-width);
  max-width: 99.99%;
}

.dual-range-input input:not([data-ready=true])::-moz-range-thumb {
  opacity: 0;
}

.dual-range-input input:hover::-moz-range-thumb {
  background-color: var(--dri-thumb-hover-color);
  border-color: var(--dri-thumb-border-hover-color);
}

.dual-range-input input:active::-moz-range-thumb {
  background-color: var(--dri-thumb-active-color);
  border-color: var(--dri-thumb-border-active-color);
}

.dual-range-input input:focus-visible::-moz-range-thumb {
  background-color: var(--dri-thumb-active-color);
  border-color: var(--dri-thumb-border-active-color);
}

.dual-range-input input::-webkit-slider-runnable-track {
  background-color: var(--dri-track-color);
  background-repeat: no-repeat;
  box-sizing: border-box;
  height: var(--dri-track-height);
}

.dual-range-input input:first-child::-webkit-slider-runnable-track {
  border-start-start-radius: var(--dri-track-border-radius);
  border-end-start-radius: var(--dri-track-border-radius);
  background-image: linear-gradient(to right, var(--dri-track-color) var(--dri-gradient-position), var(--dri-track-filled-color) var(--dri-gradient-position), var(--dri-track-filled-gradient-mid-color));
}

[dir=rtl] .dual-range-input input:first-child::-webkit-slider-runnable-track {
  background-image: linear-gradient(to left, var(--dri-track-color) var(--dri-gradient-position), var(--dri-track-filled-color) var(--dri-gradient-position), var(--dri-track-filled-gradient-mid-color));
}

.dual-range-input input:last-child::-webkit-slider-runnable-track {
  border-start-end-radius: var(--dri-track-border-radius);
  border-end-end-radius: var(--dri-track-border-radius);
  background-image: linear-gradient(to right, var(--dri-track-filled-gradient-mid-color), var(--dri-track-filled-gradient-end-color) var(--dri-gradient-position), var(--dri-track-color) var(--dri-gradient-position));
}

[dir=rtl] .dual-range-input input:last-child::-webkit-slider-runnable-track {
  background-image: linear-gradient(to left, var(--dri-track-filled-gradient-mid-color), var(--dri-track-filled-gradient-end-color) var(--dri-gradient-position), var(--dri-track-color) var(--dri-gradient-position));
}

.dual-range-input input::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  background-color: var(--dri-thumb-color);
  border-radius: var(--dri-thumb-border-radius);
  border: var(--dri-thumb-border-width) solid var(--dri-thumb-border-color);
  box-shadow: none;
  box-sizing: border-box;
  height: var(--dri-thumb-height);
  width: var(--dri-thumb-width);
  margin-top: calc(var(--dri-track-height) / 2);
  transform: translateY(-50%);
}

.dual-range-input input:not([data-ready=true])::-webkit-slider-thumb {
  opacity: 0;
}

.dual-range-input input:hover::-webkit-slider-thumb {
  background-color: var(--dri-thumb-hover-color);
  border-color: var(--dri-thumb-border-hover-color);
}

.dual-range-input input:active::-webkit-slider-thumb {
  background-color: var(--dri-thumb-active-color);
  border-color: var(--dri-thumb-border-active-color);
}

.dual-range-input input:focus-visible::-webkit-slider-thumb {
  background-color: var(--dri-thumb-active-color);
  border-color: var(--dri-thumb-border-active-color);
}


.ctrls {
  --ctrls-font:
    ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, Consolas,
    "DejaVu Sans Mono", monospace;
  --ctrls-radius: 4px;
  --ctrls-label-width: 7rem;
  --ctrls-width: 24rem;
  --ctrls-font-size: 0.75rem;
  --ctrls-value-font-size: 0.6875rem;
  --ctrls-c: 0.25;
  --ctrls-h: 245;
  --ctrls-theme: oklch(0.65 var(--ctrls-c) var(--ctrls-h));
  --ctrls-theme-oklch: 0.65 var(--ctrls-c) var(--ctrls-h);
  --ctrls-gray-50: #f1f1f1;
  --ctrls-gray-100: #e3e3e3;
  --ctrls-gray-200: #c7c7c7;
  --ctrls-gray-300: #acacac;
  --ctrls-gray-400: #929292;
  --ctrls-gray-500: #787878;
  --ctrls-scrollbar-thumb-bg: var(--ctrls-gray-400);
  --ctrls-bg: oklch(0.99 0.005 var(--ctrls-h) / 0.9);
  --ctrls-text: oklch(0.01 0.2 var(--ctrls-h));
  --ctrls-text-muted: oklch(0.5 0.005 var(--ctrls-h));
  --ctrls-hover-bg: oklch(0.98 0.03 var(--ctrls-h));
  --ctrls-border: oklch(0.925 0.01 var(--ctrls-h));
  --ctrls-input-border: oklch(0.925 0.01 var(--ctrls-h));
  --ctrls-hover-border: oklch(0.85 0.075 var(--ctrls-h));
  --ctrls-input-wrapper-bg: white;
  --ctrls-btn-bg: white;
  --ctrls-btn-hover-bg: oklch(0.98 0.02 var(--ctrls-h) / 0.5);
  --ctrls-btn-hover-text: var(--ctrls-theme);
  --ctrls-btn-selected-bg: var(--ctrls-theme);
  --ctrls-btn-selected-text: white;
  --ctrls-input-bg: white;
  --ctrls-range-track-bg: var(--ctrls-gray-100);
  --ctrls-range-track-active-bg: var(--ctrls-theme);
  --ctrls-range-thumb-bg: var(--ctrls-gray-100);
  --ctrls-range-thumb-border: var(--ctrls-gray-200);
  --ctrls-range-thumb-hover-bg: var(--ctrls-gray-200);
  --ctrls-range-thumb-hover-border: var(--ctrls-gray-300);
  --ctrls-range-thumb-active-bg: var(--ctrls-theme);
  --ctrls-range-thumb-radius: 4px;
  --ctrls-checkbox-bg: white;
  --ctrls-checkbox-radius: 4px;
  --ctrls-checkbox-hover-text: var(--ctrls-gray-200);
  --ctrls-checkbox-checked-bg: var(--ctrls-theme);
  --ctrls-checkbox-checked-text: var(--ctrls-gray-50);
  --ctrls-checkbox-checked-hover-bg: oklch(0.5 var(--ctrls-c) var(--ctrls-h));
  --ctrls-easing-border: var(--ctrls-gray-200);
  --ctrls-ctrls__easing-handle-bg: var(--ctrls-gray-50);
  --ctrls-ctrls__easing-handle-border: var(--ctrls-gray-300);
}

@media (prefers-color-scheme: dark) {
  .ctrls--system-theme {
    --ctrls-c: 0.2;
    --ctrls-theme-oklch: 0.6 var(--ctrls-c) var(--ctrls-h);
    --ctrls-theme: oklch(0.6 var(--ctrls-c) var(--ctrls-h));
    --ctrls-gray-50: #e1e1e1;
    --ctrls-gray-100: #d3d3d3;
    --ctrls-gray-200: #b7b7b7;
    --ctrls-gray-300: #9c9c9c;
    --ctrls-gray-400: #828282;
    --ctrls-gray-500: #686868;
    --ctrls-scrollbar-thumb-bg: #5f5f5f;
    --ctrls-bg: oklch(0.27 0.003 var(--ctrls-h) / 0.9);
    --ctrls-text: oklch(0.95 0.005 var(--ctrls-h));
    --ctrls-text-muted: oklch(0.75 0.005 var(--ctrls-h));
    --ctrls-hover-bg: oklch(0.23 0.03 var(--ctrls-h));
    --ctrls-border: oklch(0.35 0.01 var(--ctrls-h));
    --ctrls-input-border: transparent;
    --ctrls-hover-border: oklch(0.5 0.15 var(--ctrls-h));
    --ctrls-input-wrapper-bg: oklch(0.22 0.002 var(--ctrls-h));
    --ctrls-btn-bg: oklch(0.2 0.001 var(--ctrls-h));
    --ctrls-btn-selected-bg: oklch(0.5 var(--ctrls-c) var(--ctrls-h));
    --ctrls-btn-hover-bg: oklch(0.1 0.001 var(--ctrls-h));
    --ctrls-input-bg: var(--ctrls-input-wrapper-bg);
    --ctrls-checkbox-checked-hover-bg: oklch(0.45 var(--ctrls-c) var(--ctrls-h));
  }
}
.ctrls--dark-theme {
  --ctrls-c: 0.2;
  --ctrls-theme-oklch: 0.6 var(--ctrls-c) var(--ctrls-h);
  --ctrls-theme: oklch(0.6 var(--ctrls-c) var(--ctrls-h));
  --ctrls-gray-50: #e1e1e1;
  --ctrls-gray-100: #d3d3d3;
  --ctrls-gray-200: #b7b7b7;
  --ctrls-gray-300: #9c9c9c;
  --ctrls-gray-400: #828282;
  --ctrls-gray-500: #686868;
  --ctrls-scrollbar-thumb-bg: #5f5f5f;
  --ctrls-bg: oklch(0.27 0.003 var(--ctrls-h) / 0.9);
  --ctrls-text: oklch(0.95 0.005 var(--ctrls-h));
  --ctrls-text-muted: oklch(0.75 0.005 var(--ctrls-h));
  --ctrls-hover-bg: oklch(0.23 0.03 var(--ctrls-h));
  --ctrls-border: oklch(0.35 0.01 var(--ctrls-h));
  --ctrls-input-border: transparent;
  --ctrls-hover-border: oklch(0.5 0.15 var(--ctrls-h));
  --ctrls-input-wrapper-bg: oklch(0.22 0.002 var(--ctrls-h));
  --ctrls-btn-bg: oklch(0.2 0.001 var(--ctrls-h));
  --ctrls-btn-selected-bg: oklch(0.5 var(--ctrls-c) var(--ctrls-h));
  --ctrls-btn-hover-bg: oklch(0.1 0.001 var(--ctrls-h));
  --ctrls-input-bg: var(--ctrls-input-wrapper-bg);
  --ctrls-checkbox-checked-hover-bg: oklch(0.45 var(--ctrls-c) var(--ctrls-h));
}

.ctrls {
  box-sizing: border-box;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-variation-settings: "wdth" 100;
  font-family: var(--ctrls-font);
  font-size: var(--ctrls-font-size);
  color: var(--ctrls-text);
  border-radius: min(var(--ctrls-radius) + 8px, 24px);
  border: 1px solid var(--ctrls-border);
  background-color: var(--ctrls-bg);
  backdrop-filter: blur(4px);
  max-width: var(--ctrls-width);
  overflow: hidden;
}
.ctrls *,
.ctrls *::before,
.ctrls *::after {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
}
.ctrls button,
.ctrls input {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}
.ctrls svg {
  display: block;
  overflow: visible;
}
.ctrls img {
  max-width: 100%;
}

.ctrls button:focus-visible {
  outline: 2px solid var(--ctrls-theme);
  outline-offset: 2px;
}

.ctrls__title,
.ctrls__group-title {
  background: none;
  border: none;
  display: flex;
  gap: 0.5rem;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  font-weight: bold;
  letter-spacing: -0.025em;
  padding: 0.25rem 0.5rem;
  cursor: pointer;
  transition: color 300ms, background-color 300ms;
}
.ctrls__title:focus-visible, .ctrls__title:hover,
.ctrls__group-title:focus-visible,
.ctrls__group-title:hover {
  color: var(--ctrls-theme);
  background: var(--ctrls-hover-bg);
}
.ctrls .ctrls__title:focus-visible,
.ctrls .ctrls__group-title:focus-visible {
  outline: none;
  background-color: var(--ctrls-theme);
  color: white;
}
.ctrls__title svg,
.ctrls__group-title svg {
  transition: transform 250ms;
  width: 1rem;
}

.ctrls__controls-inner {
  display: grid;
  gap: 0.5rem;
  overflow: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--ctrls-scrollbar-thumb-bg) transparent;
}
.ctrls__controls-inner > *:last-child:not(:first-child) {
  margin-bottom: 0.5rem;
}
.ctrls__controls-inner > *:first-child:not(:last-child) {
  margin-top: 0.25rem;
}

.ctrls__drawer {
  display: none;
  align-items: flex-start;
  grid-template-rows: 0fr;
  transition: grid-template-rows 500ms, opacity 500ms, display 500ms;
  transition-behavior: allow-discrete;
  overflow: hidden;
  opacity: 0;
}

.ctrls__drawer--expanded {
  display: grid;
  grid-template-rows: 1fr;
  opacity: 1;
}

@starting-style {
  .ctrls__drawer--ready.ctrls__drawer--expanded {
    grid-template-rows: 0fr;
    opacity: 0;
  }
}
.ctrls__drawer-inner {
  overflow: hidden;
}

.ctrls__drawer-toggle--collapsed svg {
  transform: rotate(180deg);
}

.ctrls__group {
  margin-inline: 0.5rem;
  border: 1px solid var(--ctrls-border);
  border-radius: var(--ctrls-radius);
  overflow: hidden;
}
.ctrls__group:only-child {
  margin-block: 0.5rem;
}

.ctrls__group .ctrls__control {
  grid-template-columns: calc(var(--ctrls-label-width) - 0.5rem) minmax(0, 1fr);
}

.ctrls__group-controls-inner {
  display: grid;
  gap: 0.5rem;
}
.ctrls__group-controls-inner > *:first-child {
  margin-top: 0.25rem;
}
.ctrls__group-controls-inner > *:last-child {
  margin-bottom: 0.25rem;
}

.ctrls__control {
  padding: 0 0.5rem;
  display: grid;
  grid-template-columns: var(--ctrls-label-width) minmax(0, 1fr);
  align-items: center;
}
.ctrls__control:hover {
  background: var(--ctrls-hover-bg);
  box-shadow: 0 0 0 0.25rem var(--ctrls-hover-bg);
}
.ctrls__control:hover .ctrls__control-label {
  color: var(--ctrls-theme);
}
.ctrls__control:only-child {
  padding-block: 0.5rem;
}

.ctrls__control-no-label {
  padding: 0 0.5rem 0 calc(var(--ctrls-label-width) + 0.5rem);
}

.ctrls__control-label {
  color: var(--ctrls-text-muted);
  font-weight: 700;
  hyphens: auto;
  padding-right: 0.25rem;
}

.ctrls__control-value {
  font-weight: 400;
  font-size: var(--ctrls-value-font-size);
}

.ctrls__btn {
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  border-radius: var(--ctrls-radius);
  transition: color 300ms, border-color 300ms, background-color 300ms;
}
.ctrls__btn:focus-visible, .ctrls__btn:hover {
  color: var(--ctrls-btn-hover-text);
}
.ctrls__btn svg {
  width: 1rem;
  height: 1rem;
  transition: transform 300ms, color 300ms;
}
.ctrls__btn path {
  transition: opacity 300ms;
}

.ctrls__btn--sm {
  padding: 0.375rem 0.5rem;
  background: var(--ctrls-btn-bg);
  border: 1px solid var(--ctrls-input-border);
}
.ctrls__btn--sm:focus-visible, .ctrls__btn--sm:hover {
  color: var(--ctrls-theme);
  background: var(--ctrls-btn-hover-bg);
  border-color: var(--ctrls-hover-border);
}

.ctrls__btn--lg {
  width: 100%;
  padding: 0.5rem 1rem;
  background: var(--ctrls-btn-bg);
  border: 1px solid var(--ctrls-input-border);
  font-weight: 700;
}
.ctrls__btn--lg:focus-visible, .ctrls__btn--lg:hover {
  color: var(--ctrls-theme);
  background: var(--ctrls-btn-hover-bg);
  border-color: var(--ctrls-hover-border);
}

.ctrls__randomize {
  grid-column: 2;
}
.ctrls__randomize:focus-visible svg, .ctrls__randomize:hover svg {
  transform: rotate(0.5turn);
}
.ctrls__randomize:focus-visible path:nth-child(2),
.ctrls__randomize:focus-visible path:nth-child(4), .ctrls__randomize:hover path:nth-child(2),
.ctrls__randomize:hover path:nth-child(4) {
  opacity: 0;
}

.ctrls__control--boolean input {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  left: -1000vw;
}

.ctrls__boolean-checkmark {
  appearance: none;
  width: 1.125rem;
  height: 1.125rem;
  color: transparent;
  background: var(--ctrls-checkbox-bg);
  border-radius: var(--ctrls-checkbox-radius);
  border: 1px solid var(--ctrls-input-border);
  display: grid;
  place-items: center;
}
.ctrls__boolean-checkmark svg {
  width: 0.875rem;
  height: 0.875rem;
  stroke-width: 4px;
}

.ctrls__boolean-input:checked + .ctrls__boolean-checkmark {
  background: var(--ctrls-checkbox-checked-bg);
  color: var(--ctrls-checkbox-checked-text);
  border-color: transparent;
}

label:hover .ctrls__boolean-input:checked + .ctrls__boolean-checkmark {
  background: var(--ctrls-checkbox-checked-hover-bg);
}

label:hover .ctrls__boolean-input:not(:checked) + .ctrls__boolean-checkmark {
  color: var(--ctrls-checkbox-hover-text);
}

.ctrls__boolean-input:focus-visible + .ctrls__boolean-checkmark {
  outline: 2px solid var(--ctrls-theme);
  outline-offset: 2px;
}

.ctrls__range-input {
  width: 100%;
  -webkit-tap-highlight-color: transparent;
  -webkit-appearance: none;
  appearance: none;
  display: block;
  background: none;
  border-radius: 0;
  flex-basis: calc(50% + var(--dri-thumb-width));
  flex-shrink: 0;
  height: 1.5rem;
  margin: 0;
  min-width: var(--dri-thumb-width);
  outline: none;
  border-radius: var(--ctrls-radius);
}
.ctrls__range-input:focus-visible {
  outline: 2px solid var(--ctrls-theme);
  outline-offset: 2px;
}

.ctrls__range-input::-moz-range-track {
  background-color: var(--ctrls-range-track-bg);
  background-repeat: no-repeat;
  box-sizing: border-box;
  height: 0.25rem;
  border-radius: 100px;
  background-image: linear-gradient(to right, var(--ctrls-range-track-active-bg) var(--gradient-position), var(--ctrls-range-track-bg) var(--gradient-position));
}

.ctrls__range-input::-moz-range-track {
  background-color: var(--ctrls-range-track-bg);
  background-repeat: no-repeat;
  box-sizing: border-box;
  height: 0.25rem;
  border-radius: 100px;
  background-image: linear-gradient(to right, var(--ctrls-range-track-active-bg) var(--gradient-position), var(--ctrls-range-track-bg) var(--gradient-position));
}

.ctrls__range-input::-moz-range-thumb {
  -webkit-appearance: none;
  appearance: none;
  background-color: var(--ctrls-range-thumb-bg);
  border-radius: var(--ctrls-range-thumb-radius);
  border: 1px solid var(--ctrls-range-thumb-border);
  box-shadow: none;
  box-sizing: border-box;
  height: 1rem;
  width: 1.25rem;
  max-width: 99.99%;
}

.ctrls__range-input:hover::-moz-range-thumb {
  background-color: var(--ctrls-range-thumb-hover-bg);
  border-color: var(--ctrls-range-thumb-hover-border);
}

.ctrls__range-input:active::-moz-range-thumb {
  background-color: var(--ctrls-range-thumb-active-bg);
  border-color: transparent;
}

.ctrls__range-input::-webkit-slider-runnable-track {
  background-color: var(--ctrls-range-track-bg);
  background-repeat: no-repeat;
  box-sizing: border-box;
  height: 0.25rem;
  border-radius: 100px;
  background-image: linear-gradient(to right, var(--ctrls-range-track-active-bg) var(--gradient-position), var(--ctrls-range-track-bg) var(--gradient-position));
}

.ctrls__range-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  background-color: var(--ctrls-range-thumb-bg);
  border-radius: var(--ctrls-range-thumb-radius);
  border: 1px solid var(--ctrls-range-thumb-border);
  box-shadow: none;
  box-sizing: border-box;
  height: 1rem;
  width: 1.25rem;
  margin-top: 0.125rem;
  transform: translateY(-50%);
}

.ctrls__range-input:hover::-webkit-slider-thumb {
  background-color: var(--ctrls-range-thumb-hover-bg);
  border-color: var(--ctrls-range-thumb-hover-border);
}

.ctrls__control-right .dual-range-input {
  padding-inline-end: calc(var(--dri-thumb-width) * 2);
}
.ctrls__control-right .dual-range-input:has(input:focus-visible) {
  border-radius: var(--ctrls-radius);
}
.ctrls__control-right .dual-range-input {
  --dri-track-color: var(--ctrls-range-track-bg);
  --dri-track-filled-color: var(--ctrls-range-track-active-bg);
  --dri-height: 1.5rem;
  --dri-thumb-width: 1.25rem;
  --dri-thumb-height: 1rem;
  --dri-thumb-border-radius: var(--ctrls-range-thumb-radius);
  --dri-thumb-color: var(--ctrls-range-thumb-bg);
  --dri-thumb-hover-color: var(--ctrls-range-thumb-hover-bg);
  --dri-thumb-active-color: var(--ctrls-range-thumb-active-bg);
  --dri-thumb-border-color: var(--ctrls-range-thumb-border);
  --dri-thumb-border-hover-color: var(--ctrls-range-thumb-hover-border);
  --dri-thumb-border-active-color: transparent;
}
.ctrls__control-right .dual-range-input:has(input:focus-visible) {
  outline-offset: 2px;
}

.ctrls__control--radio .ctrls__control-right {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0.25rem;
}

.ctrls__radio-label {
  display: block;
  text-align: center;
  cursor: pointer;
  padding: 0.25rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color 250ms, border-color 250ms, background-color 250ms;
  border-radius: var(--ctrls-radius);
  border: 1px solid var(--ctrls-input-border);
  background: var(--ctrls-btn-bg);
}
.ctrls__radio-label:focus-visible, .ctrls__radio-label:hover {
  background: var(--ctrls-btn-hover-bg);
  border-color: var(--ctrls-hover-border);
  color: var(--ctrls-theme);
}

.ctrls__radio-label input {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  left: -1000vw;
}

.ctrls__radio-label:has(input:checked) {
  background: var(--ctrls-btn-selected-bg);
  color: var(--ctrls-btn-selected-text);
  border-color: transparent;
}

.ctrls__radio-label:has(input:focus-visible) {
  outline: 2px solid var(--ctrls-theme);
  outline-offset: 2px;
}

.ctrls__control--seed .ctrls__control-right {
  display: flex;
  gap: 0.25rem;
}

.ctrls__seed-input {
  background-color: var(--ctrls-input-bg);
  border: 1px solid var(--ctrls-input-border);
  padding: 0 0.5rem;
  height: 1.75rem;
  border-radius: var(--ctrls-radius);
  width: 0;
  flex-grow: 1;
}
.ctrls__seed-input:focus {
  outline: 2px solid var(--ctrls-theme);
  outline-offset: 2px;
}

.ctrls__seed-new-button {
  padding: 0 0.375rem;
  flex-shrink: 0;
}
.ctrls__seed-new-button:focus-visible svg, .ctrls__seed-new-button:hover svg {
  transform: rotate(0.5turn);
}

.ctrls__file-top {
  display: flex;
  gap: 0.25rem;
}

.ctrls__file-input {
  opacity: 0;
  position: absolute;
  left: -200vw;
}

.ctrls__file-fake-input {
  border-radius: var(--ctrls-radius);
  flex-grow: 1;
  font-weight: 700;
  color: var(--ctrls-text-muted);
  display: grid;
  place-items: center;
  line-height: 1;
}
.ctrls__file-fake-input span {
  display: block;
  font-weight: normal;
}

.ctrls__file-input:focus-visible + .ctrls__file-fake-input {
  outline: 2px solid var(--ctrls-theme);
  outline-offset: 2px;
}

.ctrls__file-clear {
  padding: 0 0.375rem;
  flex-shrink: 0;
}
.ctrls__file-clear path {
  transition: transform 250ms;
}
.ctrls__file-clear:hover path:nth-child(2),
.ctrls__file-clear:hover path:nth-child(3), .ctrls__file-clear:focus-visible path:nth-child(2),
.ctrls__file-clear:focus-visible path:nth-child(3) {
  transform-origin: center;
  transform: translateY(-0.25rem);
}

.ctrls__file-preview-item {
  padding: 0.25rem 0.5rem;
  background: var(--ctrls-btn-bg);
  border: 1px solid var(--ctrls-input-border);
  border-radius: var(--ctrls-radius);
  color: var(--ctrls-text-muted);
  font-weight: 700;
  margin-top: 0.25rem;
  display: grid;
  place-items: center;
  text-align: center;
}

.ctrls__file-image {
  max-height: 8rem;
  max-width: 8rem;
  border-radius: max(2px, var(--ctrls-radius) - 4px);
  margin-block: 0.25rem;
  outline-offset: -1px;
}

.ctrls__file-label {
  display: block;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  width: 100%;
}

.ctrls__easing-wrapper {
  padding: 0.5rem;
  border: 1px solid var(--ctrls-input-border);
  background: var(--ctrls-input-wrapper-bg);
  border-radius: min(var(--ctrls-radius), 12px);
}

.ctrls__easing {
  position: relative;
  margin-top: 0.5rem;
}
.ctrls__easing path,
.ctrls__easing line {
  vector-effect: non-scaling-stroke;
  fill: none;
  stroke-linecap: round;
}

.ctrls__easing-ticks {
  height: 0.375rem;
  width: 100%;
}

.ctrls__easing-ticks line {
  stroke: var(--ctrls-easing-border);
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
}

.easing-borders {
  stroke: var(--ctrls-easing-border);
  stroke-dasharray: 1 3;
}

.ctrls__easing-path {
  stroke-width: 2px;
  stroke: var(--ctrls-theme);
}

.ctrls__easing-line {
  stroke: var(--ctrls-easing-border);
  stroke-dasharray: 3;
}

.ctrls__easing-buttons {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0.25rem;
  margin-top: 0.25rem;
}

.ctrls__easing-buttons button {
  overflow: hidden;
  cursor: pointer;
  display: grid;
  align-content: center;
  text-align: center;
  border: 1px solid var(--ctrls-input-border);
  border-radius: var(--ctrls-radius);
  background: var(--ctrls-btn-bg);
  padding: 0.25rem;
  transition: color 250ms, border-color 250ms, background-color 250ms;
}
.ctrls__easing-buttons button:focus-visible, .ctrls__easing-buttons button:hover {
  background: var(--ctrls-btn-hover-bg);
  border-color: var(--ctrls-hover-border);
  color: var(--ctrls-theme);
}

.ctrls__control--radio .ctrls__control-right {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0.25rem;
}

.ctrls__easing-handle {
  background: none;
  touch-action: none;
  position: absolute;
  transform: translate(-50%, -50%);
  display: block;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  cursor: grab;
  font-size: 0;
  color: transparent;
  transition: border 250ms;
  border: 0.75rem solid transparent;
}
.ctrls__easing-handle::after {
  content: "";
  display: block;
  background-color: var(--ctrls-ctrls__easing-handle-bg);
  border: 1px solid var(--ctrls-ctrls__easing-handle-border);
  height: 100%;
  width: 100%;
  border-radius: 50%;
}
.ctrls__easing-handle:hover, .ctrls__easing-handle:focus-visible {
  border-color: oklch(var(--ctrls-theme-oklch)/0.1);
}
.ctrls__easing-handle:hover::after, .ctrls__easing-handle:focus-visible::after {
  background-color: var(--ctrls-theme);
  border: 1px solid var(--ctrls-theme);
}

/*# sourceMappingURL=ctrls.css.map */
