@layer properties {
  @supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))) {
    *, :before, :after, ::backdrop {
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-border-style: solid;
      --tw-gradient-position: initial;
      --tw-gradient-from: #0000;
      --tw-gradient-via: #0000;
      --tw-gradient-to: #0000;
      --tw-gradient-stops: initial;
      --tw-gradient-via-stops: initial;
      --tw-gradient-from-position: 0%;
      --tw-gradient-via-position: 50%;
      --tw-gradient-to-position: 100%;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-ordinal: initial;
      --tw-slashed-zero: initial;
      --tw-numeric-figure: initial;
      --tw-numeric-spacing: initial;
      --tw-numeric-fraction: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
      --tw-duration: initial;
      --tw-ease: initial;
    }
  }
}

@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --font-mono: "JBMonoIDE", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    --color-red-100: #ffe2e2;
    --color-red-200: #ffcaca;
    --color-red-300: #ffa3a3;
    --color-red-400: #ff6568;
    --color-red-500: #fb2c36;
    --color-orange-200: #ffd7a8;
    --color-orange-400: #ff8b1a;
    --color-orange-500: #fe6e00;
    --color-amber-100: #fef3c6;
    --color-amber-200: #fee685;
    --color-amber-300: #ffd236;
    --color-amber-400: #fcbb00;
    --color-amber-500: #f99c00;
    --color-emerald-100: #d0fae5;
    --color-emerald-200: #a4f4cf;
    --color-emerald-300: #5ee9b5;
    --color-emerald-400: #00d294;
    --color-emerald-500: #00bb7f;
    --color-emerald-600: #009767;
    --color-cyan-100: #cefafe;
    --color-cyan-200: #a2f4fd;
    --color-cyan-300: #53eafd;
    --color-cyan-400: #00d2ef;
    --color-cyan-500: #00b7d7;
    --color-cyan-600: #0092b5;
    --color-sky-100: #dff2fe;
    --color-sky-200: #b8e6fe;
    --color-sky-400: #00bcfe;
    --color-sky-500: #00a5ef;
    --color-indigo-950: #1e1a4d;
    --color-violet-200: #ddd6ff;
    --color-violet-300: #c4b4ff;
    --color-violet-400: #a685ff;
    --color-violet-500: #8d54ff;
    --color-rose-50: #fff1f2;
    --color-rose-100: #ffe4e6;
    --color-rose-200: #ffccd3;
    --color-rose-300: #ffa2ae;
    --color-rose-400: #ff667f;
    --color-rose-500: #ff2357;
    --color-rose-600: #e70044;
    --color-slate-50: #f8fafc;
    --color-slate-100: #f1f5f9;
    --color-slate-200: #e2e8f0;
    --color-slate-300: #cad5e2;
    --color-slate-400: #90a1b9;
    --color-slate-500: #62748e;
    --color-slate-700: #314158;
    --color-slate-800: #1d293d;
    --color-slate-900: #0f172b;
    --color-slate-950: #020618;
    --color-black: #000;
    --color-white: #fff;
    --spacing: .25rem;
    --container-md: 28rem;
    --container-xl: 36rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --container-5xl: 64rem;
    --text-xs: .75rem;
    --text-xs--line-height: calc(1 / .75);
    --text-sm: .875rem;
    --text-sm--line-height: calc(1.25 / .875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --text-7xl: 4.5rem;
    --text-7xl--line-height: 1;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --tracking-tight: -.025em;
    --tracking-normal: 0em;
    --tracking-wide: .025em;
    --tracking-wider: .05em;
    --leading-snug: 1.375;
    --leading-relaxed: 1.625;
    --radius-sm: .25rem;
    --radius-md: .375rem;
    --radius-lg: .5rem;
    --radius-xl: .75rem;
    --radius-2xl: 1rem;
    --radius-3xl: 1.5rem;
    --ease-out: cubic-bezier(.32, .72, 0, 1);
    --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite;
    --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;
    --blur-sm: 8px;
    --aspect-video: 16 / 9;
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-background: #080c16;
    --color-foreground: #f8fafc;
    --color-card: #0c1322;
    --color-card-foreground: #f8fafc;
    --color-muted: #1d283a;
    --color-muted-foreground: #94a3b8;
    --color-border: #1d283a;
    --color-accent: #07b6d5;
    --color-accent-foreground: #f8fafc;
    --color-destructive: #a51d1d;
    --color-success: #15793a;
    --color-warning: #9b6a08;
    --accent-glow: 0 0 36px -12px #07b6d58c;
    --ok: #36d397;
    --warn: #fbbd23;
    --danger: #f87272;
    --t-short: .12s;
    --t-default: .2s;
    --t-long: .36s;
    --ease-sheet: cubic-bezier(.32, .72, 0, 1);
    --text-label: 13px;
    --text-body: 14px;
    --text-section: 16px;
    --text-panel: 18px;
    --track-eyebrow: .08em;
    --surface-specular: inset 0 1px 0 #ffffff14;
  }

  @supports (color: lab(0% 0 0)) {
    :root, :host {
      --color-red-100: lab(92.243% 10.2865 3.83865);
      --color-red-200: lab(86.017% 19.8815 7.75869);
      --color-red-300: lab(76.5514% 36.422 15.5335);
      --color-red-400: lab(63.7053% 60.745 31.3109);
      --color-red-500: lab(55.4814% 75.0732 48.8528);
      --color-orange-200: lab(88.4871% 9.94918 28.8378);
      --color-orange-400: lab(70.0429% 42.5156 75.8207);
      --color-orange-500: lab(64.272% 57.1788 90.3583);
      --color-amber-100: lab(95.916% -1.21653 23.111);
      --color-amber-200: lab(91.7203% -.505269 49.9084);
      --color-amber-300: lab(86.4156% 6.13147 78.3961);
      --color-amber-400: lab(80.1641% 16.6016 99.2089);
      --color-amber-500: lab(72.7183% 31.8672 97.9407);
      --color-emerald-100: lab(94.9004% -17.0769 5.63836);
      --color-emerald-200: lab(90.2247% -31.039 9.47084);
      --color-emerald-300: lab(83.9203% -48.7124 13.8849);
      --color-emerald-400: lab(75.0771% -60.7313 19.4147);
      --color-emerald-500: lab(66.9756% -58.27 19.5419);
      --color-emerald-600: lab(55.0481% -49.9246 15.93);
      --color-cyan-100: lab(95.3146% -13.8285 -6.84732);
      --color-cyan-200: lab(91.0821% -24.0435 -12.8306);
      --color-cyan-300: lab(85.3886% -36.7636 -21.5716);
      --color-cyan-400: lab(76.6045% -40.9406 -29.6231);
      --color-cyan-500: lab(67.805% -35.3952 -30.2018);
      --color-cyan-600: lab(55.1767% -26.7496 -30.5139);
      --color-sky-100: lab(94.3709% -4.56053 -8.23453);
      --color-sky-200: lab(88.6983% -11.3978 -16.8488);
      --color-sky-400: lab(70.687% -23.6078 -45.9483);
      --color-sky-500: lab(63.3038% -18.433 -51.0407);
      --color-indigo-950: lab(12.4853% 14.9672 -31.3418);
      --color-violet-200: lab(87.0888% 8.53688 -19.4189);
      --color-violet-300: lab(76.7419% 18.3911 -37.0706);
      --color-violet-400: lab(62.8239% 34.9159 -60.0512);
      --color-violet-500: lab(49.9355% 55.1776 -81.8963);
      --color-rose-50: lab(96.2369% 4.94155 1.28011);
      --color-rose-100: lab(92.8221% 9.86832 2.60075);
      --color-rose-200: lab(86.806% 19.1909 4.07754);
      --color-rose-300: lab(76.6339% 38.3549 9.68835);
      --color-rose-400: lab(64.4125% 63.0291 19.2068);
      --color-rose-500: lab(56.101% 79.4328 31.4532);
      --color-rose-600: lab(49.1882% 81.577 36.0311);
      --color-slate-50: lab(98.1434% -.369519 -1.05966);
      --color-slate-100: lab(96.286% -.852436 -2.46847);
      --color-slate-200: lab(91.7353% -.998765 -4.76968);
      --color-slate-300: lab(84.7652% -1.94535 -7.93337);
      --color-slate-400: lab(65.5349% -2.25151 -14.5072);
      --color-slate-500: lab(48.0876% -2.03595 -16.5814);
      --color-slate-700: lab(26.9569% -1.47016 -15.6993);
      --color-slate-800: lab(16.132% -.318035 -14.6672);
      --color-slate-900: lab(7.78673% 1.82345 -15.0537);
      --color-slate-950: lab(1.76974% 1.32743 -9.28855);
    }
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }

  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }

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

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

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

  b, strong {
    font-weight: bolder;
  }

  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }

  small {
    font-size: 80%;
  }

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

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.5em;
  }

  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }

  :-moz-focusring {
    outline: auto;
  }

  progress {
    vertical-align: baseline;
  }

  summary {
    display: list-item;
  }

  ol, ul, menu {
    list-style: none;
  }

  img, svg, video, canvas, audio, iframe, embed, object {
    vertical-align: middle;
    display: block;
  }

  img, video {
    max-width: 100%;
    height: auto;
  }

  button, input, select, optgroup, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }

  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }

  ::file-selector-button {
    margin-inline-end: 4px;
  }

  ::placeholder {
    opacity: 1;
  }

  @supports (not ((-webkit-appearance: -apple-pay-button))) or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentColor;
    }

    @supports (color: color-mix(in lab, red, red)) {
      ::placeholder {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }

  textarea {
    resize: vertical;
  }

  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }

  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }

  ::-webkit-datetime-edit {
    display: inline-flex;
  }

  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }

  ::-webkit-datetime-edit {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }

  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }

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

  button, input:where([type="button"], [type="reset"], [type="submit"]) {
    appearance: button;
  }

  ::file-selector-button {
    appearance: button;
  }

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

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

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }

  html {
    font-size: 16px;
  }

  html, body {
    background: var(--color-background);
    color: var(--color-foreground);
  }

  body {
    font-family: var(--font-sans);
    font-size: 14px;
    line-height: 1.5;
  }

  *, :before, :after {
    font-size: inherit;
  }

  .text-xs, .text-\[11px\], .text-\[10px\] {
    line-height: 16px;
    font-size: 12px !important;
  }

  input, textarea, select {
    font-size: 16px;
  }

  :focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
  }

  ::selection {
    background: var(--color-accent);
    color: var(--color-accent-foreground);
  }

  button:not(.target-exempt), [role="button"]:not(.target-exempt), a.touch-target:not(.target-exempt), input[type="button"]:not(.target-exempt), input[type="submit"]:not(.target-exempt), input[type="reset"]:not(.target-exempt), input[type="checkbox"]:not(.target-exempt), input[type="radio"]:not(.target-exempt), select:not(.target-exempt) {
    min-width: 44px;
    min-height: 44px;
  }

  button:not(:disabled), [role="button"] {
    min-block-size: 44px;
  }
}

@layer components;

@layer utilities {
  .collapse {
    visibility: collapse;
  }

  .invisible {
    visibility: hidden;
  }

  .visible {
    visibility: visible;
  }

  .sr-only {
    clip-path: inset(50%);
    white-space: nowrap;
    border-width: 0;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    position: absolute;
    overflow: hidden;
  }

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .relative {
    position: relative;
  }

  .static {
    position: static;
  }

  .sticky {
    position: sticky;
  }

  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }

  .inset-x-0 {
    inset-inline: calc(var(--spacing) * 0);
  }

  .top-1\/2 {
    top: 50%;
  }

  .right-3 {
    right: calc(var(--spacing) * 3);
  }

  .bottom-0 {
    bottom: calc(var(--spacing) * 0);
  }

  .bottom-3 {
    bottom: calc(var(--spacing) * 3);
  }

  .left-3 {
    left: calc(var(--spacing) * 3);
  }

  .z-40 {
    z-index: 40;
  }

  .z-50 {
    z-index: 50;
  }

  .col-span-2 {
    grid-column: span 2 / span 2;
  }

  .col-span-full {
    grid-column: 1 / -1;
  }

  .container {
    width: 100%;
  }

  @media (min-width: 40rem) {
    .container {
      max-width: 40rem;
    }
  }

  @media (min-width: 48rem) {
    .container {
      max-width: 48rem;
    }
  }

  @media (min-width: 64rem) {
    .container {
      max-width: 64rem;
    }
  }

  @media (min-width: 80rem) {
    .container {
      max-width: 80rem;
    }
  }

  @media (min-width: 96rem) {
    .container {
      max-width: 96rem;
    }
  }

  .m-3 {
    margin: calc(var(--spacing) * 3);
  }

  .mt-0\.5 {
    margin-top: calc(var(--spacing) * .5);
  }

  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }

  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }

  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }

  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }

  .mt-5 {
    margin-top: calc(var(--spacing) * 5);
  }

  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }

  .mt-auto {
    margin-top: auto;
  }

  .mr-1 {
    margin-right: calc(var(--spacing) * 1);
  }

  .mr-2 {
    margin-right: calc(var(--spacing) * 2);
  }

  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }

  .mb-1\.5 {
    margin-bottom: calc(var(--spacing) * 1.5);
  }

  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }

  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }

  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }

  .mb-5 {
    margin-bottom: calc(var(--spacing) * 5);
  }

  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }

  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }

  .ml-0\.5 {
    margin-left: calc(var(--spacing) * .5);
  }

  .ml-1 {
    margin-left: calc(var(--spacing) * 1);
  }

  .ml-2 {
    margin-left: calc(var(--spacing) * 2);
  }

  .ml-auto {
    margin-left: auto;
  }

  .line-clamp-2 {
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
  }

  .line-clamp-3 {
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
  }

  .line-clamp-4 {
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
  }

  .block {
    display: block;
  }

  .contents {
    display: contents;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

  .inline {
    display: inline;
  }

  .inline-block {
    display: inline-block;
  }

  .inline-flex {
    display: inline-flex;
  }

  .table {
    display: table;
  }

  .aspect-\[4\/3\] {
    aspect-ratio: 4 / 3;
  }

  .aspect-video {
    aspect-ratio: var(--aspect-video);
  }

  .h-1\.5 {
    height: calc(var(--spacing) * 1.5);
  }

  .h-2 {
    height: calc(var(--spacing) * 2);
  }

  .h-3 {
    height: calc(var(--spacing) * 3);
  }

  .h-3\.5 {
    height: calc(var(--spacing) * 3.5);
  }

  .h-4 {
    height: calc(var(--spacing) * 4);
  }

  .h-5 {
    height: calc(var(--spacing) * 5);
  }

  .h-6 {
    height: calc(var(--spacing) * 6);
  }

  .h-7 {
    height: calc(var(--spacing) * 7);
  }

  .h-8 {
    height: calc(var(--spacing) * 8);
  }

  .h-9 {
    height: calc(var(--spacing) * 9);
  }

  .h-10 {
    height: calc(var(--spacing) * 10);
  }

  .h-11 {
    height: calc(var(--spacing) * 11);
  }

  .h-12 {
    height: calc(var(--spacing) * 12);
  }

  .h-14 {
    height: calc(var(--spacing) * 14);
  }

  .h-16 {
    height: calc(var(--spacing) * 16);
  }

  .h-20 {
    height: calc(var(--spacing) * 20);
  }

  .h-28 {
    height: calc(var(--spacing) * 28);
  }

  .h-32 {
    height: calc(var(--spacing) * 32);
  }

  .h-36 {
    height: calc(var(--spacing) * 36);
  }

  .h-44 {
    height: calc(var(--spacing) * 44);
  }

  .h-48 {
    height: calc(var(--spacing) * 48);
  }

  .h-64 {
    height: calc(var(--spacing) * 64);
  }

  .h-full {
    height: 100%;
  }

  .max-h-24 {
    max-height: calc(var(--spacing) * 24);
  }

  .max-h-40 {
    max-height: calc(var(--spacing) * 40);
  }

  .max-h-64 {
    max-height: calc(var(--spacing) * 64);
  }

  .max-h-72 {
    max-height: calc(var(--spacing) * 72);
  }

  .max-h-\[60vh\] {
    max-height: 60vh;
  }

  .max-h-\[70vh\] {
    max-height: 70vh;
  }

  .max-h-\[90vh\] {
    max-height: 90vh;
  }

  .max-h-\[140px\] {
    max-height: 140px;
  }

  .max-h-\[300px\] {
    max-height: 300px;
  }

  .max-h-\[400px\] {
    max-height: 400px;
  }

  .max-h-\[420px\] {
    max-height: 420px;
  }

  .max-h-\[480px\] {
    max-height: 480px;
  }

  .max-h-\[640px\] {
    max-height: 640px;
  }

  .max-h-full {
    max-height: 100%;
  }

  .min-h-\[40vh\] {
    min-height: 40vh;
  }

  .min-h-\[44px\] {
    min-height: 44px;
  }

  .min-h-\[56px\] {
    min-height: 56px;
  }

  .min-h-\[60vh\] {
    min-height: 60vh;
  }

  .min-h-\[64px\] {
    min-height: 64px;
  }

  .min-h-\[80px\] {
    min-height: 80px;
  }

  .min-h-\[88px\] {
    min-height: 88px;
  }

  .min-h-\[96px\] {
    min-height: 96px;
  }

  .min-h-\[100px\] {
    min-height: 100px;
  }

  .min-h-\[120px\] {
    min-height: 120px;
  }

  .min-h-\[140px\] {
    min-height: 140px;
  }

  .min-h-\[160px\] {
    min-height: 160px;
  }

  .min-h-\[180px\] {
    min-height: 180px;
  }

  .min-h-\[200px\] {
    min-height: 200px;
  }

  .min-h-\[220px\] {
    min-height: 220px;
  }

  .min-h-\[260px\] {
    min-height: 260px;
  }

  .min-h-\[280px\] {
    min-height: 280px;
  }

  .min-h-\[300px\] {
    min-height: 300px;
  }

  .min-h-\[320px\] {
    min-height: 320px;
  }

  .min-h-\[360px\] {
    min-height: 360px;
  }

  .min-h-\[400px\] {
    min-height: 400px;
  }

  .min-h-screen {
    min-height: 100vh;
  }

  .w-1\.5 {
    width: calc(var(--spacing) * 1.5);
  }

  .w-2 {
    width: calc(var(--spacing) * 2);
  }

  .w-2\/3 {
    width: 66.6667%;
  }

  .w-3 {
    width: calc(var(--spacing) * 3);
  }

  .w-3\.5 {
    width: calc(var(--spacing) * 3.5);
  }

  .w-3\/4 {
    width: 75%;
  }

  .w-4 {
    width: calc(var(--spacing) * 4);
  }

  .w-5 {
    width: calc(var(--spacing) * 5);
  }

  .w-7 {
    width: calc(var(--spacing) * 7);
  }

  .w-8 {
    width: calc(var(--spacing) * 8);
  }

  .w-11 {
    width: calc(var(--spacing) * 11);
  }

  .w-12 {
    width: calc(var(--spacing) * 12);
  }

  .w-16 {
    width: calc(var(--spacing) * 16);
  }

  .w-20 {
    width: calc(var(--spacing) * 20);
  }

  .w-24 {
    width: calc(var(--spacing) * 24);
  }

  .w-28 {
    width: calc(var(--spacing) * 28);
  }

  .w-32 {
    width: calc(var(--spacing) * 32);
  }

  .w-40 {
    width: calc(var(--spacing) * 40);
  }

  .w-44 {
    width: calc(var(--spacing) * 44);
  }

  .w-48 {
    width: calc(var(--spacing) * 48);
  }

  .w-56 {
    width: calc(var(--spacing) * 56);
  }

  .w-64 {
    width: calc(var(--spacing) * 64);
  }

  .w-72 {
    width: calc(var(--spacing) * 72);
  }

  .w-80 {
    width: calc(var(--spacing) * 80);
  }

  .w-96 {
    width: calc(var(--spacing) * 96);
  }

  .w-\[140px\] {
    width: 140px;
  }

  .w-\[200px\] {
    width: 200px;
  }

  .w-\[220px\] {
    width: 220px;
  }

  .w-\[240px\] {
    width: 240px;
  }

  .w-full {
    width: 100%;
  }

  .max-w-2xl {
    max-width: var(--container-2xl);
  }

  .max-w-3xl {
    max-width: var(--container-3xl);
  }

  .max-w-4xl {
    max-width: var(--container-4xl);
  }

  .max-w-5xl {
    max-width: var(--container-5xl);
  }

  .max-w-\[16rem\] {
    max-width: 16rem;
  }

  .max-w-\[85\%\] {
    max-width: 85%;
  }

  .max-w-\[180px\] {
    max-width: 180px;
  }

  .max-w-full {
    max-width: 100%;
  }

  .max-w-md {
    max-width: var(--container-md);
  }

  .max-w-none {
    max-width: none;
  }

  .max-w-xl {
    max-width: var(--container-xl);
  }

  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }

  .min-w-\[44px\] {
    min-width: 44px;
  }

  .min-w-\[64px\] {
    min-width: 64px;
  }

  .min-w-\[88px\] {
    min-width: 88px;
  }

  .min-w-\[120px\] {
    min-width: 120px;
  }

  .min-w-\[140px\] {
    min-width: 140px;
  }

  .min-w-\[180px\] {
    min-width: 180px;
  }

  .min-w-\[200px\] {
    min-width: 200px;
  }

  .min-w-full {
    min-width: 100%;
  }

  .flex-1 {
    flex: 1;
  }

  .shrink {
    flex-shrink: 1;
  }

  .shrink-0 {
    flex-shrink: 0;
  }

  .grow {
    flex-grow: 1;
  }

  .-translate-y-1\/2 {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .transform {
    transform: var(--tw-rotate-x, ) var(--tw-rotate-y, ) var(--tw-rotate-z, ) var(--tw-skew-x, ) var(--tw-skew-y, );
  }

  .animate-pulse {
    animation: var(--animate-pulse);
  }

  .cursor-grab {
    cursor: grab;
  }

  .cursor-move {
    cursor: move;
  }

  .cursor-not-allowed {
    cursor: not-allowed;
  }

  .cursor-pointer {
    cursor: pointer;
  }

  .resize {
    resize: both;
  }

  .resize-y {
    resize: vertical;
  }

  .list-decimal {
    list-style-type: decimal;
  }

  .list-disc {
    list-style-type: disc;
  }

  .list-none {
    list-style-type: 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-\[1fr_2fr\] {
    grid-template-columns: 1fr 2fr;
  }

  .grid-cols-\[1fr_auto\] {
    grid-template-columns: 1fr auto;
  }

  .grid-cols-\[auto_1fr_auto\] {
    grid-template-columns: auto 1fr auto;
  }

  .flex-col {
    flex-direction: column;
  }

  .flex-wrap {
    flex-wrap: wrap;
  }

  .items-baseline {
    align-items: baseline;
  }

  .items-center {
    align-items: center;
  }

  .items-end {
    align-items: flex-end;
  }

  .items-start {
    align-items: flex-start;
  }

  .justify-between {
    justify-content: space-between;
  }

  .justify-center {
    justify-content: center;
  }

  .justify-end {
    justify-content: flex-end;
  }

  .justify-start {
    justify-content: flex-start;
  }

  .gap-0\.5 {
    gap: calc(var(--spacing) * .5);
  }

  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }

  .gap-1\.5 {
    gap: calc(var(--spacing) * 1.5);
  }

  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }

  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }

  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }

  .gap-5 {
    gap: calc(var(--spacing) * 5);
  }

  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }

  :where(.space-y-0\.5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * .5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * .5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-1 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-1\.5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-2 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-3 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-4 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-6 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
  }

  .gap-x-3 {
    column-gap: calc(var(--spacing) * 3);
  }

  .gap-x-4 {
    column-gap: calc(var(--spacing) * 4);
  }

  .gap-x-6 {
    column-gap: calc(var(--spacing) * 6);
  }

  .gap-x-8 {
    column-gap: calc(var(--spacing) * 8);
  }

  .gap-y-1 {
    row-gap: calc(var(--spacing) * 1);
  }

  .gap-y-2 {
    row-gap: calc(var(--spacing) * 2);
  }

  .gap-y-3 {
    row-gap: calc(var(--spacing) * 3);
  }

  .self-center {
    align-self: center;
  }

  .self-end {
    align-self: flex-end;
  }

  .self-start {
    align-self: flex-start;
  }

  .truncate {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden;
  }

  .overflow-auto {
    overflow: auto;
  }

  .overflow-hidden {
    overflow: hidden;
  }

  .overflow-x-auto {
    overflow-x: auto;
  }

  .overflow-y-auto {
    overflow-y: auto;
  }

  .overscroll-contain {
    overscroll-behavior: contain;
  }

  .rounded {
    border-radius: .25rem;
  }

  .rounded-2xl {
    border-radius: var(--radius-2xl);
  }

  .rounded-3xl {
    border-radius: var(--radius-3xl);
  }

  .rounded-full {
    border-radius: 3.40282e38px;
  }

  .rounded-lg {
    border-radius: var(--radius-lg);
  }

  .rounded-md {
    border-radius: var(--radius-md);
  }

  .rounded-sm {
    border-radius: var(--radius-sm);
  }

  .rounded-xl {
    border-radius: var(--radius-xl);
  }

  .rounded-t-3xl {
    border-top-left-radius: var(--radius-3xl);
    border-top-right-radius: var(--radius-3xl);
  }

  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }

  .border-2 {
    border-style: var(--tw-border-style);
    border-width: 2px;
  }

  .border-\[16px\] {
    border-style: var(--tw-border-style);
    border-width: 16px;
  }

  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }

  .border-t-2 {
    border-top-style: var(--tw-border-style);
    border-top-width: 2px;
  }

  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }

  .border-l {
    border-left-style: var(--tw-border-style);
    border-left-width: 1px;
  }

  .border-l-2 {
    border-left-style: var(--tw-border-style);
    border-left-width: 2px;
  }

  .border-l-4 {
    border-left-style: var(--tw-border-style);
    border-left-width: 4px;
  }

  .border-\[var\(--color-border\)\] {
    border-color: var(--color-border);
  }

  .border-\[var\(--color-destructive\)\] {
    border-color: var(--color-destructive);
  }

  .border-\[var\(--color-success\)\] {
    border-color: var(--color-success);
  }

  .border-\[var\(--color-warning\)\] {
    border-color: var(--color-warning);
  }

  .border-amber-400\/30 {
    border-color: #fcbb004d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-amber-400\/30 {
      border-color: color-mix(in oklab, var(--color-amber-400) 30%, transparent);
    }
  }

  .border-amber-400\/40 {
    border-color: #fcbb0066;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-amber-400\/40 {
      border-color: color-mix(in oklab, var(--color-amber-400) 40%, transparent);
    }
  }

  .border-amber-400\/50 {
    border-color: #fcbb0080;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-amber-400\/50 {
      border-color: color-mix(in oklab, var(--color-amber-400) 50%, transparent);
    }
  }

  .border-amber-400\/60 {
    border-color: #fcbb0099;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-amber-400\/60 {
      border-color: color-mix(in oklab, var(--color-amber-400) 60%, transparent);
    }
  }

  .border-cyan-400\/20 {
    border-color: #00d2ef33;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-cyan-400\/20 {
      border-color: color-mix(in oklab, var(--color-cyan-400) 20%, transparent);
    }
  }

  .border-cyan-400\/30 {
    border-color: #00d2ef4d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-cyan-400\/30 {
      border-color: color-mix(in oklab, var(--color-cyan-400) 30%, transparent);
    }
  }

  .border-cyan-400\/40 {
    border-color: #00d2ef66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-cyan-400\/40 {
      border-color: color-mix(in oklab, var(--color-cyan-400) 40%, transparent);
    }
  }

  .border-cyan-400\/50 {
    border-color: #00d2ef80;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-cyan-400\/50 {
      border-color: color-mix(in oklab, var(--color-cyan-400) 50%, transparent);
    }
  }

  .border-cyan-400\/60 {
    border-color: #00d2ef99;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-cyan-400\/60 {
      border-color: color-mix(in oklab, var(--color-cyan-400) 60%, transparent);
    }
  }

  .border-emerald-400\/20 {
    border-color: #00d29433;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-emerald-400\/20 {
      border-color: color-mix(in oklab, var(--color-emerald-400) 20%, transparent);
    }
  }

  .border-emerald-400\/30 {
    border-color: #00d2944d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-emerald-400\/30 {
      border-color: color-mix(in oklab, var(--color-emerald-400) 30%, transparent);
    }
  }

  .border-emerald-400\/40 {
    border-color: #00d29466;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-emerald-400\/40 {
      border-color: color-mix(in oklab, var(--color-emerald-400) 40%, transparent);
    }
  }

  .border-emerald-400\/60 {
    border-color: #00d29499;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-emerald-400\/60 {
      border-color: color-mix(in oklab, var(--color-emerald-400) 60%, transparent);
    }
  }

  .border-orange-400\/40 {
    border-color: #ff8b1a66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-orange-400\/40 {
      border-color: color-mix(in oklab, var(--color-orange-400) 40%, transparent);
    }
  }

  .border-red-400\/60 {
    border-color: #ff656899;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-red-400\/60 {
      border-color: color-mix(in oklab, var(--color-red-400) 60%, transparent);
    }
  }

  .border-red-500\/40 {
    border-color: #fb2c3666;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-red-500\/40 {
      border-color: color-mix(in oklab, var(--color-red-500) 40%, transparent);
    }
  }

  .border-rose-400\/20 {
    border-color: #ff667f33;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-rose-400\/20 {
      border-color: color-mix(in oklab, var(--color-rose-400) 20%, transparent);
    }
  }

  .border-rose-400\/30 {
    border-color: #ff667f4d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-rose-400\/30 {
      border-color: color-mix(in oklab, var(--color-rose-400) 30%, transparent);
    }
  }

  .border-rose-400\/40 {
    border-color: #ff667f66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-rose-400\/40 {
      border-color: color-mix(in oklab, var(--color-rose-400) 40%, transparent);
    }
  }

  .border-rose-400\/50 {
    border-color: #ff667f80;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-rose-400\/50 {
      border-color: color-mix(in oklab, var(--color-rose-400) 50%, transparent);
    }
  }

  .border-rose-400\/60 {
    border-color: #ff667f99;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-rose-400\/60 {
      border-color: color-mix(in oklab, var(--color-rose-400) 60%, transparent);
    }
  }

  .border-rose-500\/30 {
    border-color: #ff23574d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-rose-500\/30 {
      border-color: color-mix(in oklab, var(--color-rose-500) 30%, transparent);
    }
  }

  .border-rose-500\/70 {
    border-color: #ff2357b3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-rose-500\/70 {
      border-color: color-mix(in oklab, var(--color-rose-500) 70%, transparent);
    }
  }

  .border-sky-400\/40 {
    border-color: #00bcfe66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-sky-400\/40 {
      border-color: color-mix(in oklab, var(--color-sky-400) 40%, transparent);
    }
  }

  .border-slate-500\/30 {
    border-color: #62748e4d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-slate-500\/30 {
      border-color: color-mix(in oklab, var(--color-slate-500) 30%, transparent);
    }
  }

  .border-slate-500\/40 {
    border-color: #62748e66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-slate-500\/40 {
      border-color: color-mix(in oklab, var(--color-slate-500) 40%, transparent);
    }
  }

  .border-transparent {
    border-color: #0000;
  }

  .border-violet-400\/20 {
    border-color: #a685ff33;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-violet-400\/20 {
      border-color: color-mix(in oklab, var(--color-violet-400) 20%, transparent);
    }
  }

  .border-violet-400\/30 {
    border-color: #a685ff4d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-violet-400\/30 {
      border-color: color-mix(in oklab, var(--color-violet-400) 30%, transparent);
    }
  }

  .border-violet-400\/40 {
    border-color: #a685ff66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-violet-400\/40 {
      border-color: color-mix(in oklab, var(--color-violet-400) 40%, transparent);
    }
  }

  .border-white\/5 {
    border-color: #ffffff0d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-white\/5 {
      border-color: color-mix(in oklab, var(--color-white) 5%, transparent);
    }
  }

  .border-white\/10 {
    border-color: #ffffff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-white\/10 {
      border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }

  .border-white\/15 {
    border-color: #ffffff26;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-white\/15 {
      border-color: color-mix(in oklab, var(--color-white) 15%, transparent);
    }
  }

  .border-white\/20 {
    border-color: #fff3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .border-white\/20 {
      border-color: color-mix(in oklab, var(--color-white) 20%, transparent);
    }
  }

  .bg-\[var\(--color-accent\)\] {
    background-color: var(--color-accent);
  }

  .bg-\[var\(--color-background\)\] {
    background-color: var(--color-background);
  }

  .bg-\[var\(--color-card\)\] {
    background-color: var(--color-card);
  }

  .bg-\[var\(--color-destructive\)\] {
    background-color: var(--color-destructive);
  }

  .bg-\[var\(--color-muted\)\] {
    background-color: var(--color-muted);
  }

  .bg-\[var\(--color-success\)\] {
    background-color: var(--color-success);
  }

  .bg-\[var\(--color-warning\)\] {
    background-color: var(--color-warning);
  }

  .bg-amber-300 {
    background-color: var(--color-amber-300);
  }

  .bg-amber-400 {
    background-color: var(--color-amber-400);
  }

  .bg-amber-500\/5 {
    background-color: #f99c000d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-amber-500\/5 {
      background-color: color-mix(in oklab, var(--color-amber-500) 5%, transparent);
    }
  }

  .bg-amber-500\/10 {
    background-color: #f99c001a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-amber-500\/10 {
      background-color: color-mix(in oklab, var(--color-amber-500) 10%, transparent);
    }
  }

  .bg-amber-500\/15 {
    background-color: #f99c0026;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-amber-500\/15 {
      background-color: color-mix(in oklab, var(--color-amber-500) 15%, transparent);
    }
  }

  .bg-amber-500\/20 {
    background-color: #f99c0033;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-amber-500\/20 {
      background-color: color-mix(in oklab, var(--color-amber-500) 20%, transparent);
    }
  }

  .bg-black\/20 {
    background-color: #0003;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/20 {
      background-color: color-mix(in oklab, var(--color-black) 20%, transparent);
    }
  }

  .bg-black\/30 {
    background-color: #0000004d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/30 {
      background-color: color-mix(in oklab, var(--color-black) 30%, transparent);
    }
  }

  .bg-black\/40 {
    background-color: #0006;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/40 {
      background-color: color-mix(in oklab, var(--color-black) 40%, transparent);
    }
  }

  .bg-black\/50 {
    background-color: #00000080;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/50 {
      background-color: color-mix(in oklab, var(--color-black) 50%, transparent);
    }
  }

  .bg-black\/60 {
    background-color: #0009;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/60 {
      background-color: color-mix(in oklab, var(--color-black) 60%, transparent);
    }
  }

  .bg-cyan-300 {
    background-color: var(--color-cyan-300);
  }

  .bg-cyan-500 {
    background-color: var(--color-cyan-500);
  }

  .bg-cyan-500\/5 {
    background-color: #00b7d70d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-cyan-500\/5 {
      background-color: color-mix(in oklab, var(--color-cyan-500) 5%, transparent);
    }
  }

  .bg-cyan-500\/10 {
    background-color: #00b7d71a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-cyan-500\/10 {
      background-color: color-mix(in oklab, var(--color-cyan-500) 10%, transparent);
    }
  }

  .bg-cyan-500\/15 {
    background-color: #00b7d726;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-cyan-500\/15 {
      background-color: color-mix(in oklab, var(--color-cyan-500) 15%, transparent);
    }
  }

  .bg-emerald-300 {
    background-color: var(--color-emerald-300);
  }

  .bg-emerald-400 {
    background-color: var(--color-emerald-400);
  }

  .bg-emerald-400\/70 {
    background-color: #00d294b3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-emerald-400\/70 {
      background-color: color-mix(in oklab, var(--color-emerald-400) 70%, transparent);
    }
  }

  .bg-emerald-500 {
    background-color: var(--color-emerald-500);
  }

  .bg-emerald-500\/5 {
    background-color: #00bb7f0d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-emerald-500\/5 {
      background-color: color-mix(in oklab, var(--color-emerald-500) 5%, transparent);
    }
  }

  .bg-emerald-500\/10 {
    background-color: #00bb7f1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-emerald-500\/10 {
      background-color: color-mix(in oklab, var(--color-emerald-500) 10%, transparent);
    }
  }

  .bg-emerald-500\/15 {
    background-color: #00bb7f26;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-emerald-500\/15 {
      background-color: color-mix(in oklab, var(--color-emerald-500) 15%, transparent);
    }
  }

  .bg-emerald-500\/20 {
    background-color: #00bb7f33;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-emerald-500\/20 {
      background-color: color-mix(in oklab, var(--color-emerald-500) 20%, transparent);
    }
  }

  .bg-orange-500\/20 {
    background-color: #fe6e0033;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-orange-500\/20 {
      background-color: color-mix(in oklab, var(--color-orange-500) 20%, transparent);
    }
  }

  .bg-red-500\/10 {
    background-color: #fb2c361a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-red-500\/10 {
      background-color: color-mix(in oklab, var(--color-red-500) 10%, transparent);
    }
  }

  .bg-red-500\/20 {
    background-color: #fb2c3633;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-red-500\/20 {
      background-color: color-mix(in oklab, var(--color-red-500) 20%, transparent);
    }
  }

  .bg-rose-300 {
    background-color: var(--color-rose-300);
  }

  .bg-rose-400 {
    background-color: var(--color-rose-400);
  }

  .bg-rose-500 {
    background-color: var(--color-rose-500);
  }

  .bg-rose-500\/5 {
    background-color: #ff23570d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-rose-500\/5 {
      background-color: color-mix(in oklab, var(--color-rose-500) 5%, transparent);
    }
  }

  .bg-rose-500\/10 {
    background-color: #ff23571a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-rose-500\/10 {
      background-color: color-mix(in oklab, var(--color-rose-500) 10%, transparent);
    }
  }

  .bg-rose-500\/15 {
    background-color: #ff235726;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-rose-500\/15 {
      background-color: color-mix(in oklab, var(--color-rose-500) 15%, transparent);
    }
  }

  .bg-rose-500\/20 {
    background-color: #ff235733;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-rose-500\/20 {
      background-color: color-mix(in oklab, var(--color-rose-500) 20%, transparent);
    }
  }

  .bg-rose-500\/30 {
    background-color: #ff23574d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-rose-500\/30 {
      background-color: color-mix(in oklab, var(--color-rose-500) 30%, transparent);
    }
  }

  .bg-sky-500\/10 {
    background-color: #00a5ef1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sky-500\/10 {
      background-color: color-mix(in oklab, var(--color-sky-500) 10%, transparent);
    }
  }

  .bg-sky-500\/20 {
    background-color: #00a5ef33;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-sky-500\/20 {
      background-color: color-mix(in oklab, var(--color-sky-500) 20%, transparent);
    }
  }

  .bg-slate-400 {
    background-color: var(--color-slate-400);
  }

  .bg-slate-500\/15 {
    background-color: #62748e26;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-500\/15 {
      background-color: color-mix(in oklab, var(--color-slate-500) 15%, transparent);
    }
  }

  .bg-slate-700\/10 {
    background-color: #3141581a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-700\/10 {
      background-color: color-mix(in oklab, var(--color-slate-700) 10%, transparent);
    }
  }

  .bg-slate-700\/20 {
    background-color: #31415833;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-700\/20 {
      background-color: color-mix(in oklab, var(--color-slate-700) 20%, transparent);
    }
  }

  .bg-slate-700\/30 {
    background-color: #3141584d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-700\/30 {
      background-color: color-mix(in oklab, var(--color-slate-700) 30%, transparent);
    }
  }

  .bg-slate-700\/40 {
    background-color: #31415866;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-700\/40 {
      background-color: color-mix(in oklab, var(--color-slate-700) 40%, transparent);
    }
  }

  .bg-slate-800 {
    background-color: var(--color-slate-800);
  }

  .bg-slate-800\/80 {
    background-color: #1d293dcc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-800\/80 {
      background-color: color-mix(in oklab, var(--color-slate-800) 80%, transparent);
    }
  }

  .bg-slate-900 {
    background-color: var(--color-slate-900);
  }

  .bg-slate-900\/40 {
    background-color: #0f172b66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-900\/40 {
      background-color: color-mix(in oklab, var(--color-slate-900) 40%, transparent);
    }
  }

  .bg-slate-900\/50 {
    background-color: #0f172b80;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-900\/50 {
      background-color: color-mix(in oklab, var(--color-slate-900) 50%, transparent);
    }
  }

  .bg-slate-900\/60 {
    background-color: #0f172b99;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-900\/60 {
      background-color: color-mix(in oklab, var(--color-slate-900) 60%, transparent);
    }
  }

  .bg-slate-900\/70 {
    background-color: #0f172bb3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-900\/70 {
      background-color: color-mix(in oklab, var(--color-slate-900) 70%, transparent);
    }
  }

  .bg-slate-900\/95 {
    background-color: #0f172bf2;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-900\/95 {
      background-color: color-mix(in oklab, var(--color-slate-900) 95%, transparent);
    }
  }

  .bg-slate-950\/40 {
    background-color: #02061866;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-950\/40 {
      background-color: color-mix(in oklab, var(--color-slate-950) 40%, transparent);
    }
  }

  .bg-slate-950\/60 {
    background-color: #02061899;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-950\/60 {
      background-color: color-mix(in oklab, var(--color-slate-950) 60%, transparent);
    }
  }

  .bg-slate-950\/80 {
    background-color: #020618cc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-slate-950\/80 {
      background-color: color-mix(in oklab, var(--color-slate-950) 80%, transparent);
    }
  }

  .bg-transparent {
    background-color: #0000;
  }

  .bg-violet-500\/5 {
    background-color: #8d54ff0d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-violet-500\/5 {
      background-color: color-mix(in oklab, var(--color-violet-500) 5%, transparent);
    }
  }

  .bg-violet-500\/10 {
    background-color: #8d54ff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-violet-500\/10 {
      background-color: color-mix(in oklab, var(--color-violet-500) 10%, transparent);
    }
  }

  .bg-violet-500\/15 {
    background-color: #8d54ff26;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-violet-500\/15 {
      background-color: color-mix(in oklab, var(--color-violet-500) 15%, transparent);
    }
  }

  .bg-white\/5 {
    background-color: #ffffff0d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-white\/5 {
      background-color: color-mix(in oklab, var(--color-white) 5%, transparent);
    }
  }

  .bg-white\/10 {
    background-color: #ffffff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-white\/10 {
      background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }

  .bg-white\/\[0\.03\] {
    background-color: #ffffff08;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-white\/\[0\.03\] {
      background-color: color-mix(in oklab, var(--color-white) 3%, transparent);
    }
  }

  .bg-white\/\[0\.04\] {
    background-color: #ffffff0a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-white\/\[0\.04\] {
      background-color: color-mix(in oklab, var(--color-white) 4%, transparent);
    }
  }

  .bg-white\/\[0\.06\] {
    background-color: #ffffff0f;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-white\/\[0\.06\] {
      background-color: color-mix(in oklab, var(--color-white) 6%, transparent);
    }
  }

  .bg-gradient-to-br {
    --tw-gradient-position: to bottom right in oklab;
    background-image: linear-gradient(var(--tw-gradient-stops));
  }

  .from-slate-950 {
    --tw-gradient-from: var(--color-slate-950);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .via-slate-950 {
    --tw-gradient-via: var(--color-slate-950);
    --tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-via-stops);
  }

  .to-indigo-950 {
    --tw-gradient-to: var(--color-indigo-950);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }

  .fill-cyan-400\/70 {
    fill: #00d2efb3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .fill-cyan-400\/70 {
      fill: color-mix(in oklab, var(--color-cyan-400) 70%, transparent);
    }
  }

  .fill-slate-50 {
    fill: var(--color-slate-50);
  }

  .fill-slate-300 {
    fill: var(--color-slate-300);
  }

  .fill-slate-400 {
    fill: var(--color-slate-400);
  }

  .fill-slate-500 {
    fill: var(--color-slate-500);
  }

  .object-cover {
    object-fit: cover;
  }

  .object-top {
    object-position: top;
  }

  .p-1 {
    padding: calc(var(--spacing) * 1);
  }

  .p-2 {
    padding: calc(var(--spacing) * 2);
  }

  .p-2\.5 {
    padding: calc(var(--spacing) * 2.5);
  }

  .p-3 {
    padding: calc(var(--spacing) * 3);
  }

  .p-4 {
    padding: calc(var(--spacing) * 4);
  }

  .p-5 {
    padding: calc(var(--spacing) * 5);
  }

  .p-6 {
    padding: calc(var(--spacing) * 6);
  }

  .p-7 {
    padding: calc(var(--spacing) * 7);
  }

  .p-8 {
    padding: calc(var(--spacing) * 8);
  }

  .px-1 {
    padding-inline: calc(var(--spacing) * 1);
  }

  .px-1\.5 {
    padding-inline: calc(var(--spacing) * 1.5);
  }

  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }

  .px-2\.5 {
    padding-inline: calc(var(--spacing) * 2.5);
  }

  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }

  .px-3\.5 {
    padding-inline: calc(var(--spacing) * 3.5);
  }

  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }

  .px-5 {
    padding-inline: calc(var(--spacing) * 5);
  }

  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }

  .px-8 {
    padding-inline: calc(var(--spacing) * 8);
  }

  .py-0\.5 {
    padding-block: calc(var(--spacing) * .5);
  }

  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }

  .py-1\.5 {
    padding-block: calc(var(--spacing) * 1.5);
  }

  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }

  .py-2\.5 {
    padding-block: calc(var(--spacing) * 2.5);
  }

  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }

  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }

  .py-6 {
    padding-block: calc(var(--spacing) * 6);
  }

  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }

  .pt-1 {
    padding-top: calc(var(--spacing) * 1);
  }

  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }

  .pt-3 {
    padding-top: calc(var(--spacing) * 3);
  }

  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }

  .pt-8 {
    padding-top: calc(var(--spacing) * 8);
  }

  .pt-20 {
    padding-top: calc(var(--spacing) * 20);
  }

  .pr-5 {
    padding-right: calc(var(--spacing) * 5);
  }

  .pb-1 {
    padding-bottom: calc(var(--spacing) * 1);
  }

  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }

  .pb-24 {
    padding-bottom: calc(var(--spacing) * 24);
  }

  .pl-2 {
    padding-left: calc(var(--spacing) * 2);
  }

  .pl-3 {
    padding-left: calc(var(--spacing) * 3);
  }

  .pl-4 {
    padding-left: calc(var(--spacing) * 4);
  }

  .pl-5 {
    padding-left: calc(var(--spacing) * 5);
  }

  .pl-6 {
    padding-left: calc(var(--spacing) * 6);
  }

  .text-center {
    text-align: center;
  }

  .text-left {
    text-align: left;
  }

  .text-right {
    text-align: right;
  }

  .align-middle {
    vertical-align: middle;
  }

  .align-text-bottom {
    vertical-align: text-bottom;
  }

  .font-mono {
    font-family: var(--font-mono);
  }

  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }

  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }

  .text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--tw-leading, var(--text-4xl--line-height));
  }

  .text-5xl {
    font-size: var(--text-5xl);
    line-height: var(--tw-leading, var(--text-5xl--line-height));
  }

  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }

  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }

  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }

  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }

  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }

  .text-\[10px\] {
    font-size: 10px;
  }

  .text-\[11px\] {
    font-size: 11px;
  }

  .leading-none {
    --tw-leading: 1;
    line-height: 1;
  }

  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }

  .leading-snug {
    --tw-leading: var(--leading-snug);
    line-height: var(--leading-snug);
  }

  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }

  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }

  .font-normal {
    --tw-font-weight: var(--font-weight-normal);
    font-weight: var(--font-weight-normal);
  }

  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .tracking-normal {
    --tw-tracking: var(--tracking-normal);
    letter-spacing: var(--tracking-normal);
  }

  .tracking-tight {
    --tw-tracking: var(--tracking-tight);
    letter-spacing: var(--tracking-tight);
  }

  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }

  .tracking-wider {
    --tw-tracking: var(--tracking-wider);
    letter-spacing: var(--tracking-wider);
  }

  .break-words {
    overflow-wrap: break-word;
  }

  .break-all {
    word-break: break-all;
  }

  .whitespace-nowrap {
    white-space: nowrap;
  }

  .whitespace-pre-wrap {
    white-space: pre-wrap;
  }

  .text-\[var\(--color-accent-foreground\)\] {
    color: var(--color-accent-foreground);
  }

  .text-\[var\(--color-card-foreground\)\] {
    color: var(--color-card-foreground);
  }

  .text-\[var\(--color-destructive\)\] {
    color: var(--color-destructive);
  }

  .text-\[var\(--color-muted-foreground\)\] {
    color: var(--color-muted-foreground);
  }

  .text-\[var\(--color-warning\)\] {
    color: var(--color-warning);
  }

  .text-amber-100 {
    color: var(--color-amber-100);
  }

  .text-amber-200 {
    color: var(--color-amber-200);
  }

  .text-amber-200\/80 {
    color: #fee685cc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-amber-200\/80 {
      color: color-mix(in oklab, var(--color-amber-200) 80%, transparent);
    }
  }

  .text-amber-300 {
    color: var(--color-amber-300);
  }

  .text-amber-400\/70 {
    color: #fcbb00b3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-amber-400\/70 {
      color: color-mix(in oklab, var(--color-amber-400) 70%, transparent);
    }
  }

  .text-black {
    color: var(--color-black);
  }

  .text-cyan-100 {
    color: var(--color-cyan-100);
  }

  .text-cyan-200 {
    color: var(--color-cyan-200);
  }

  .text-cyan-200\/90 {
    color: #a2f4fde6;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-cyan-200\/90 {
      color: color-mix(in oklab, var(--color-cyan-200) 90%, transparent);
    }
  }

  .text-cyan-300 {
    color: var(--color-cyan-300);
  }

  .text-cyan-300\/60 {
    color: #53eafd99;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-cyan-300\/60 {
      color: color-mix(in oklab, var(--color-cyan-300) 60%, transparent);
    }
  }

  .text-cyan-300\/70 {
    color: #53eafdb3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-cyan-300\/70 {
      color: color-mix(in oklab, var(--color-cyan-300) 70%, transparent);
    }
  }

  .text-cyan-300\/80 {
    color: #53eafdcc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-cyan-300\/80 {
      color: color-mix(in oklab, var(--color-cyan-300) 80%, transparent);
    }
  }

  .text-emerald-100 {
    color: var(--color-emerald-100);
  }

  .text-emerald-200 {
    color: var(--color-emerald-200);
  }

  .text-emerald-200\/80 {
    color: #a4f4cfcc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-emerald-200\/80 {
      color: color-mix(in oklab, var(--color-emerald-200) 80%, transparent);
    }
  }

  .text-emerald-300 {
    color: var(--color-emerald-300);
  }

  .text-emerald-300\/70 {
    color: #5ee9b5b3;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-emerald-300\/70 {
      color: color-mix(in oklab, var(--color-emerald-300) 70%, transparent);
    }
  }

  .text-emerald-300\/80 {
    color: #5ee9b5cc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-emerald-300\/80 {
      color: color-mix(in oklab, var(--color-emerald-300) 80%, transparent);
    }
  }

  .text-emerald-300\/90 {
    color: #5ee9b5e6;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-emerald-300\/90 {
      color: color-mix(in oklab, var(--color-emerald-300) 90%, transparent);
    }
  }

  .text-orange-200 {
    color: var(--color-orange-200);
  }

  .text-red-100 {
    color: var(--color-red-100);
  }

  .text-red-200 {
    color: var(--color-red-200);
  }

  .text-red-300 {
    color: var(--color-red-300);
  }

  .text-rose-50 {
    color: var(--color-rose-50);
  }

  .text-rose-100 {
    color: var(--color-rose-100);
  }

  .text-rose-200 {
    color: var(--color-rose-200);
  }

  .text-rose-200\/80 {
    color: #ffccd3cc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-rose-200\/80 {
      color: color-mix(in oklab, var(--color-rose-200) 80%, transparent);
    }
  }

  .text-rose-300 {
    color: var(--color-rose-300);
  }

  .text-rose-300\/80 {
    color: #ffa2aecc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-rose-300\/80 {
      color: color-mix(in oklab, var(--color-rose-300) 80%, transparent);
    }
  }

  .text-rose-300\/90 {
    color: #ffa2aee6;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-rose-300\/90 {
      color: color-mix(in oklab, var(--color-rose-300) 90%, transparent);
    }
  }

  .text-sky-100 {
    color: var(--color-sky-100);
  }

  .text-sky-200 {
    color: var(--color-sky-200);
  }

  .text-slate-50 {
    color: var(--color-slate-50);
  }

  .text-slate-100 {
    color: var(--color-slate-100);
  }

  .text-slate-200 {
    color: var(--color-slate-200);
  }

  .text-slate-200\/90 {
    color: #e2e8f0e6;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-slate-200\/90 {
      color: color-mix(in oklab, var(--color-slate-200) 90%, transparent);
    }
  }

  .text-slate-300 {
    color: var(--color-slate-300);
  }

  .text-slate-300\/80 {
    color: #cad5e2cc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-slate-300\/80 {
      color: color-mix(in oklab, var(--color-slate-300) 80%, transparent);
    }
  }

  .text-slate-300\/90 {
    color: #cad5e2e6;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-slate-300\/90 {
      color: color-mix(in oklab, var(--color-slate-300) 90%, transparent);
    }
  }

  .text-slate-400 {
    color: var(--color-slate-400);
  }

  .text-slate-400\/80 {
    color: #90a1b9cc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .text-slate-400\/80 {
      color: color-mix(in oklab, var(--color-slate-400) 80%, transparent);
    }
  }

  .text-slate-500 {
    color: var(--color-slate-500);
  }

  .text-slate-950 {
    color: var(--color-slate-950);
  }

  .text-violet-200 {
    color: var(--color-violet-200);
  }

  .text-violet-300 {
    color: var(--color-violet-300);
  }

  .text-white {
    color: var(--color-white);
  }

  .lowercase {
    text-transform: lowercase;
  }

  .normal-case {
    text-transform: none;
  }

  .uppercase {
    text-transform: uppercase;
  }

  .italic {
    font-style: italic;
  }

  .lining-nums {
    --tw-numeric-figure: lining-nums;
    font-variant-numeric: var(--tw-ordinal, ) var(--tw-slashed-zero, ) var(--tw-numeric-figure, ) var(--tw-numeric-spacing, ) var(--tw-numeric-fraction, );
  }

  .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, );
  }

  .line-through {
    text-decoration-line: line-through;
  }

  .no-underline {
    text-decoration-line: none;
  }

  .underline {
    text-decoration-line: underline;
  }

  .placeholder-slate-400::placeholder {
    color: var(--color-slate-400);
  }

  .accent-cyan-500 {
    accent-color: var(--color-cyan-500);
  }

  .opacity-40 {
    opacity: .4;
  }

  .opacity-50 {
    opacity: .5;
  }

  .opacity-60 {
    opacity: .6;
  }

  .opacity-70 {
    opacity: .7;
  }

  .opacity-80 {
    opacity: .8;
  }

  .opacity-90 {
    opacity: .9;
  }

  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-2xl {
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, #00000040);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-\[0_-8px_24px_-12px_rgba\(0\,0\,0\,0\.8\)\] {
    --tw-shadow: 0 -8px 24px -12px var(--tw-shadow-color, #000c);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-\[0_0_24px_-4px_rgba\(6\,182\,212\,0\.6\)\] {
    --tw-shadow: 0 0 24px -4px var(--tw-shadow-color, #06b6d499);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-\[0_0_24px_-4px_rgba\(244\,63\,94\,0\.6\)\] {
    --tw-shadow: 0 0 24px -4px var(--tw-shadow-color, #f43f5e99);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-sm {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring-2 {
    --tw-ring-shadow: var(--tw-ring-inset, ) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .ring-white\/40 {
    --tw-ring-color: #fff6;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .ring-white\/40 {
      --tw-ring-color: color-mix(in oklab, var(--color-white) 40%, transparent);
    }
  }

  .ring-offset-0 {
    --tw-ring-offset-width: 0px;
    --tw-ring-offset-shadow: var(--tw-ring-inset, ) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  }

  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }

  .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, );
  }

  .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);
    -webkit-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: 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(var(--blur-sm));
    -webkit-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: 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 {
    -webkit-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: 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, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-\[transform\,background-color\,border-color\,box-shadow\] {
    transition-property: transform, background-color, border-color, box-shadow;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-\[transform\,background-color\,box-shadow\] {
    transition-property: transform, background-color, box-shadow;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .duration-150 {
    --tw-duration: .15s;
    transition-duration: .15s;
  }

  .ease-\[var\(--ease-out\)\] {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-out);
  }

  .outline-none {
    --tw-outline-style: none;
    outline-style: none;
  }

  .select-none {
    -webkit-user-select: none;
    user-select: none;
  }

  .\[animation-delay\:-0\.3s\] {
    animation-delay: -.3s;
  }

  .\[animation-delay\:-0\.15s\] {
    animation-delay: -.15s;
  }

  .group-open\/domain\:rotate-180:is(:where(.group\/domain):is([open], :popover-open, :open) *) {
    rotate: 180deg;
  }

  .group-open\/orphans\:rotate-180:is(:where(.group\/orphans):is([open], :popover-open, :open) *) {
    rotate: 180deg;
  }

  .group-open\/skill\:rotate-180:is(:where(.group\/skill):is([open], :popover-open, :open) *) {
    rotate: 180deg;
  }

  .group-open\/unmapped\:rotate-180:is(:where(.group\/unmapped):is([open], :popover-open, :open) *) {
    rotate: 180deg;
  }

  .placeholder\:text-slate-400::placeholder {
    color: var(--color-slate-400);
  }

  .first\:border-t-0:first-child {
    border-top-style: var(--tw-border-style);
    border-top-width: 0;
  }

  @media (hover: hover) {
    .hover\:border-white\/20:hover {
      border-color: #fff3;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:border-white\/20:hover {
        border-color: color-mix(in oklab, var(--color-white) 20%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-\[var\(--color-muted\)\]:hover {
      background-color: var(--color-muted);
    }
  }

  @media (hover: hover) {
    .hover\:bg-amber-500\/30:hover {
      background-color: #f99c004d;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-amber-500\/30:hover {
        background-color: color-mix(in oklab, var(--color-amber-500) 30%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-cyan-400:hover {
      background-color: var(--color-cyan-400);
    }
  }

  @media (hover: hover) {
    .hover\:bg-emerald-500\/20:hover {
      background-color: #00bb7f33;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-emerald-500\/20:hover {
        background-color: color-mix(in oklab, var(--color-emerald-500) 20%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-emerald-500\/30:hover {
      background-color: #00bb7f4d;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-emerald-500\/30:hover {
        background-color: color-mix(in oklab, var(--color-emerald-500) 30%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-red-500\/30:hover {
      background-color: #fb2c364d;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-red-500\/30:hover {
        background-color: color-mix(in oklab, var(--color-red-500) 30%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-rose-400:hover {
      background-color: var(--color-rose-400);
    }
  }

  @media (hover: hover) {
    .hover\:bg-rose-500\/20:hover {
      background-color: #ff235733;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-rose-500\/20:hover {
        background-color: color-mix(in oklab, var(--color-rose-500) 20%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-rose-500\/30:hover {
      background-color: #ff23574d;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-rose-500\/30:hover {
        background-color: color-mix(in oklab, var(--color-rose-500) 30%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-rose-500\/40:hover {
      background-color: #ff235766;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-rose-500\/40:hover {
        background-color: color-mix(in oklab, var(--color-rose-500) 40%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-slate-700\/80:hover {
      background-color: #314158cc;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-slate-700\/80:hover {
        background-color: color-mix(in oklab, var(--color-slate-700) 80%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-white\/5:hover {
      background-color: #ffffff0d;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-white\/5:hover {
        background-color: color-mix(in oklab, var(--color-white) 5%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:bg-white\/10:hover {
      background-color: #ffffff1a;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .hover\:bg-white\/10:hover {
        background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
      }
    }
  }

  @media (hover: hover) {
    .hover\:opacity-90:hover {
      opacity: .9;
    }
  }

  @media (hover: hover) {
    .hover\:opacity-100:hover {
      opacity: 1;
    }
  }

  .focus\:outline:focus {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }

  .focus\:outline-2:focus {
    outline-style: var(--tw-outline-style);
    outline-width: 2px;
  }

  .focus\:outline-cyan-400:focus {
    outline-color: var(--color-cyan-400);
  }

  .focus-visible\:outline:focus-visible {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }

  .focus-visible\:outline-2:focus-visible {
    outline-style: var(--tw-outline-style);
    outline-width: 2px;
  }

  .focus-visible\:outline-offset-2:focus-visible {
    outline-offset: 2px;
  }

  .focus-visible\:outline-\[var\(--color-accent\)\]:focus-visible {
    outline-color: var(--color-accent);
  }

  .focus-visible\:outline-cyan-400:focus-visible {
    outline-color: var(--color-cyan-400);
  }

  .focus-visible\:outline-emerald-300:focus-visible {
    outline-color: var(--color-emerald-300);
  }

  .active\:scale-\[0\.97\]:active {
    scale: .97;
  }

  .active\:scale-\[0\.98\]:active {
    scale: .98;
  }

  .active\:scale-\[0\.99\]:active {
    scale: .99;
  }

  .active\:bg-amber-500\/20:active {
    background-color: #f99c0033;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-amber-500\/20:active {
      background-color: color-mix(in oklab, var(--color-amber-500) 20%, transparent);
    }
  }

  .active\:bg-amber-500\/40:active {
    background-color: #f99c0066;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-amber-500\/40:active {
      background-color: color-mix(in oklab, var(--color-amber-500) 40%, transparent);
    }
  }

  .active\:bg-cyan-500\/15:active {
    background-color: #00b7d726;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-cyan-500\/15:active {
      background-color: color-mix(in oklab, var(--color-cyan-500) 15%, transparent);
    }
  }

  .active\:bg-cyan-500\/20:active {
    background-color: #00b7d733;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-cyan-500\/20:active {
      background-color: color-mix(in oklab, var(--color-cyan-500) 20%, transparent);
    }
  }

  .active\:bg-cyan-600:active {
    background-color: var(--color-cyan-600);
  }

  .active\:bg-emerald-500\/20:active {
    background-color: #00bb7f33;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-emerald-500\/20:active {
      background-color: color-mix(in oklab, var(--color-emerald-500) 20%, transparent);
    }
  }

  .active\:bg-emerald-500\/30:active {
    background-color: #00bb7f4d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-emerald-500\/30:active {
      background-color: color-mix(in oklab, var(--color-emerald-500) 30%, transparent);
    }
  }

  .active\:bg-emerald-500\/40:active {
    background-color: #00bb7f66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-emerald-500\/40:active {
      background-color: color-mix(in oklab, var(--color-emerald-500) 40%, transparent);
    }
  }

  .active\:bg-emerald-600:active {
    background-color: var(--color-emerald-600);
  }

  .active\:bg-red-500\/40:active {
    background-color: #fb2c3666;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-red-500\/40:active {
      background-color: color-mix(in oklab, var(--color-red-500) 40%, transparent);
    }
  }

  .active\:bg-rose-500\/20:active {
    background-color: #ff235733;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-rose-500\/20:active {
      background-color: color-mix(in oklab, var(--color-rose-500) 20%, transparent);
    }
  }

  .active\:bg-rose-500\/30:active {
    background-color: #ff23574d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-rose-500\/30:active {
      background-color: color-mix(in oklab, var(--color-rose-500) 30%, transparent);
    }
  }

  .active\:bg-rose-600:active {
    background-color: var(--color-rose-600);
  }

  .active\:bg-sky-500\/20:active {
    background-color: #00a5ef33;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-sky-500\/20:active {
      background-color: color-mix(in oklab, var(--color-sky-500) 20%, transparent);
    }
  }

  .active\:bg-sky-500\/30:active {
    background-color: #00a5ef4d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-sky-500\/30:active {
      background-color: color-mix(in oklab, var(--color-sky-500) 30%, transparent);
    }
  }

  .active\:bg-slate-700:active {
    background-color: var(--color-slate-700);
  }

  .active\:bg-violet-500\/20:active {
    background-color: #8d54ff33;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-violet-500\/20:active {
      background-color: color-mix(in oklab, var(--color-violet-500) 20%, transparent);
    }
  }

  .active\:bg-white\/5:active {
    background-color: #ffffff0d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-white\/5:active {
      background-color: color-mix(in oklab, var(--color-white) 5%, transparent);
    }
  }

  .active\:bg-white\/10:active {
    background-color: #ffffff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-white\/10:active {
      background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }

  .active\:bg-white\/15:active {
    background-color: #ffffff26;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .active\:bg-white\/15:active {
      background-color: color-mix(in oklab, var(--color-white) 15%, transparent);
    }
  }

  .disabled\:cursor-not-allowed:disabled {
    cursor: not-allowed;
  }

  .disabled\:opacity-40:disabled {
    opacity: .4;
  }

  .disabled\:opacity-50:disabled {
    opacity: .5;
  }

  .disabled\:opacity-60:disabled {
    opacity: .6;
  }

  .disabled\:saturate-0:disabled {
    --tw-saturate: saturate(0%);
    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, );
  }

  .aria-selected\:bg-\[var\(--color-muted\)\][aria-selected="true"] {
    background-color: var(--color-muted);
  }

  @supports ((-webkit-backdrop-filter: var(--tw)) or (backdrop-filter: var(--tw))) {
    .supports-\[backdrop-filter\]\:bg-slate-950\/70 {
      background-color: #020618b3;
    }

    @supports (color: color-mix(in lab, red, red)) {
      .supports-\[backdrop-filter\]\:bg-slate-950\/70 {
        background-color: color-mix(in oklab, var(--color-slate-950) 70%, transparent);
      }
    }
  }

  @media (prefers-reduced-motion: no-preference) {
    .motion-safe\:animate-ping {
      animation: var(--animate-ping);
    }
  }

  @media (prefers-reduced-motion: no-preference) {
    .motion-safe\:animate-pulse {
      animation: var(--animate-pulse);
    }
  }

  @media (min-width: 40rem) {
    .sm\:left-auto {
      left: auto;
    }
  }

  @media (min-width: 40rem) {
    .sm\:mb-6 {
      margin-bottom: calc(var(--spacing) * 6);
    }
  }

  @media (min-width: 40rem) {
    .sm\:w-1\/2 {
      width: 50%;
    }
  }

  @media (min-width: 40rem) {
    .sm\:max-w-2xl {
      max-width: var(--container-2xl);
    }
  }

  @media (min-width: 40rem) {
    .sm\:max-w-md {
      max-width: var(--container-md);
    }
  }

  @media (min-width: 40rem) {
    .sm\:max-w-xl {
      max-width: var(--container-xl);
    }
  }

  @media (min-width: 40rem) {
    .sm\:flex-1 {
      flex: 1;
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-5 {
      grid-template-columns: repeat(5, minmax(0, 1fr));
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-\[1fr_auto\] {
      grid-template-columns: 1fr auto;
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-\[200px_1fr\] {
      grid-template-columns: 200px 1fr;
    }
  }

  @media (min-width: 40rem) {
    .sm\:flex-row {
      flex-direction: row;
    }
  }

  @media (min-width: 40rem) {
    .sm\:items-baseline {
      align-items: baseline;
    }
  }

  @media (min-width: 40rem) {
    .sm\:items-center {
      align-items: center;
    }
  }

  @media (min-width: 40rem) {
    .sm\:items-start {
      align-items: flex-start;
    }
  }

  @media (min-width: 40rem) {
    .sm\:gap-3 {
      gap: calc(var(--spacing) * 3);
    }
  }

  @media (min-width: 40rem) {
    .sm\:gap-5 {
      gap: calc(var(--spacing) * 5);
    }
  }

  @media (min-width: 40rem) {
    .sm\:self-start {
      align-self: flex-start;
    }
  }

  @media (min-width: 40rem) {
    .sm\:p-4 {
      padding: calc(var(--spacing) * 4);
    }
  }

  @media (min-width: 40rem) {
    .sm\:p-5 {
      padding: calc(var(--spacing) * 5);
    }
  }

  @media (min-width: 40rem) {
    .sm\:p-6 {
      padding: calc(var(--spacing) * 6);
    }
  }

  @media (min-width: 40rem) {
    .sm\:p-8 {
      padding: calc(var(--spacing) * 8);
    }
  }

  @media (min-width: 40rem) {
    .sm\:text-3xl {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
    }
  }

  @media (min-width: 40rem) {
    .sm\:text-4xl {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }

  @media (min-width: 40rem) {
    .sm\:text-5xl {
      font-size: var(--text-5xl);
      line-height: var(--tw-leading, var(--text-5xl--line-height));
    }
  }

  @media (min-width: 40rem) {
    .sm\:text-7xl {
      font-size: var(--text-7xl);
      line-height: var(--tw-leading, var(--text-7xl--line-height));
    }
  }

  @media (min-width: 48rem) {
    .md\:block {
      display: block;
    }
  }

  @media (min-width: 48rem) {
    .md\:hidden {
      display: none;
    }
  }

  @media (min-width: 48rem) {
    .md\:max-h-\[80vh\] {
      max-height: 80vh;
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-\[260px_minmax\(0\,1fr\)\] {
      grid-template-columns: 260px minmax(0, 1fr);
    }
  }

  @media (min-width: 48rem) {
    .md\:overflow-auto {
      overflow: auto;
    }
  }

  @media (min-width: 64rem) {
    .lg\:col-span-3 {
      grid-column: span 3 / span 3;
    }
  }

  @media (min-width: 64rem) {
    .lg\:col-span-6 {
      grid-column: span 6 / span 6;
    }
  }

  @media (min-width: 64rem) {
    .lg\:col-span-12 {
      grid-column: span 12 / span 12;
    }
  }

  @media (min-width: 64rem) {
    .lg\:row-span-2 {
      grid-row: span 2 / span 2;
    }
  }

  @media (min-width: 64rem) {
    .lg\:w-full {
      width: 100%;
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-6 {
      grid-template-columns: repeat(6, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-12 {
      grid-template-columns: repeat(12, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-\[260px_1fr\] {
      grid-template-columns: 260px 1fr;
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-\[260px_minmax\(0\,1fr\)\] {
      grid-template-columns: 260px minmax(0, 1fr);
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-\[280px_minmax\(0\,1fr\)\] {
      grid-template-columns: 280px minmax(0, 1fr);
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-\[300px_1fr\] {
      grid-template-columns: 300px 1fr;
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-\[320px_1fr\] {
      grid-template-columns: 320px 1fr;
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-\[minmax\(320px\,420px\)_1fr\] {
      grid-template-columns: minmax(320px, 420px) 1fr;
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-\[minmax\(320px\,460px\)_1fr\] {
      grid-template-columns: minmax(320px, 460px) 1fr;
    }
  }

  @media (min-width: 64rem) {
    .lg\:flex-col {
      flex-direction: column;
    }
  }

  @media (min-width: 64rem) {
    .lg\:p-8 {
      padding: calc(var(--spacing) * 8);
    }
  }

  @media (min-width: 80rem) {
    .xl\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 80rem) {
    .xl\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (orientation: portrait) {
    .portrait\:min-h-\[60vh\] {
      min-height: 60vh;
    }
  }

  @media (orientation: landscape) {
    .landscape\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  .\[\&_a\]\:text-cyan-300 a {
    color: var(--color-cyan-300);
  }

  .\[\&_a\]\:underline a {
    text-decoration-line: underline;
  }

  .\[\&_blockquote\]\:border-l-4 blockquote {
    border-left-style: var(--tw-border-style);
    border-left-width: 4px;
  }

  .\[\&_blockquote\]\:border-cyan-400\/40 blockquote {
    border-color: #00d2ef66;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .\[\&_blockquote\]\:border-cyan-400\/40 blockquote {
      border-color: color-mix(in oklab, var(--color-cyan-400) 40%, transparent);
    }
  }

  .\[\&_blockquote\]\:pl-4 blockquote {
    padding-left: calc(var(--spacing) * 4);
  }

  .\[\&_blockquote\]\:text-slate-300\/80 blockquote {
    color: #cad5e2cc;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .\[\&_blockquote\]\:text-slate-300\/80 blockquote {
      color: color-mix(in oklab, var(--color-slate-300) 80%, transparent);
    }
  }

  .\[\&_code\]\:rounded code {
    border-radius: .25rem;
  }

  .\[\&_code\]\:bg-white\/10 code {
    background-color: #ffffff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .\[\&_code\]\:bg-white\/10 code {
      background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }

  .\[\&_code\]\:px-1 code {
    padding-inline: calc(var(--spacing) * 1);
  }

  .\[\&_h1\]\:text-2xl h1 {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }

  .\[\&_h1\]\:font-bold h1 {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }

  .\[\&_h2\]\:mt-6 h2 {
    margin-top: calc(var(--spacing) * 6);
  }

  .\[\&_h2\]\:text-xl h2 {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }

  .\[\&_h2\]\:font-semibold h2 {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .\[\&_h3\]\:mt-4 h3 {
    margin-top: calc(var(--spacing) * 4);
  }

  .\[\&_h3\]\:text-lg h3 {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }

  .\[\&_h3\]\:font-semibold h3 {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .\[\&_hr\]\:my-4 hr {
    margin-block: calc(var(--spacing) * 4);
  }

  .\[\&_hr\]\:border-white\/10 hr {
    border-color: #ffffff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .\[\&_hr\]\:border-white\/10 hr {
      border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }

  .\[\&_li\]\:my-1 li {
    margin-block: calc(var(--spacing) * 1);
  }

  .\[\&_ol\]\:list-decimal ol {
    list-style-type: decimal;
  }

  .\[\&_ol\]\:pl-6 ol {
    padding-left: calc(var(--spacing) * 6);
  }

  .\[\&_p\]\:my-3 p {
    margin-block: calc(var(--spacing) * 3);
  }

  .\[\&_pre\]\:overflow-auto pre {
    overflow: auto;
  }

  .\[\&_pre\]\:rounded-2xl pre {
    border-radius: var(--radius-2xl);
  }

  .\[\&_pre\]\:bg-slate-900 pre {
    background-color: var(--color-slate-900);
  }

  .\[\&_pre\]\:p-4 pre {
    padding: calc(var(--spacing) * 4);
  }

  .\[\&_pre_code\]\:bg-transparent pre code {
    background-color: #0000;
  }

  .\[\&_ul\]\:list-disc ul {
    list-style-type: disc;
  }

  .\[\&_ul\]\:pl-6 ul {
    padding-left: calc(var(--spacing) * 6);
  }

  .touch-row {
    gap: 16px;
    display: flex;
  }
}

@view-transition {
  navigation: auto;
}

.react-grid-layout {
  transition: height .2s;
  position: relative;
}

.react-grid-item {
  transition: left .2s, top .2s, width .2s, height .2s;
}

.react-grid-item.cssTransforms {
  transition-property: transform, width, height;
}

.react-grid-item.resizing {
  z-index: 1;
  will-change: width, height;
}

.react-grid-item.react-draggable-dragging {
  z-index: 3;
  will-change: transform;
  cursor: grabbing;
  transition: none;
}

.react-grid-item > .react-resizable-handle {
  cursor: se-resize;
  background-image: linear-gradient(135deg, transparent 50%, var(--color-muted-foreground) 50%, var(--color-muted-foreground) 60%, transparent 60%);
  width: 16px;
  height: 16px;
  position: absolute;
  bottom: 0;
  right: 0;
}

@media (prefers-reduced-motion: reduce) {
  .react-grid-item, .react-grid-layout {
    transition: none !important;
  }
}

.touch-gap {
  gap: 24px;
}

.touch-gap-lg {
  gap: 32px;
}

@media (prefers-reduced-motion: reduce) {
  *, :before, :after {
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
  }
}

@media (prefers-reduced-transparency: reduce) {
  .backdrop-blur, [class*="backdrop-blur"] {
    -webkit-backdrop-filter: none !important;
    background-color: var(--color-card) !important;
  }
}

@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-rotate-x {
  syntax: "*";
  inherits: false
}

@property --tw-rotate-y {
  syntax: "*";
  inherits: false
}

@property --tw-rotate-z {
  syntax: "*";
  inherits: false
}

@property --tw-skew-x {
  syntax: "*";
  inherits: false
}

@property --tw-skew-y {
  syntax: "*";
  inherits: false
}

@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}

@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-gradient-position {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-from {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-via {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-to {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}

@property --tw-gradient-stops {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-via-stops {
  syntax: "*";
  inherits: false
}

@property --tw-gradient-from-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0%;
}

@property --tw-gradient-via-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 50%;
}

@property --tw-gradient-to-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-leading {
  syntax: "*";
  inherits: false
}

@property --tw-font-weight {
  syntax: "*";
  inherits: false
}

@property --tw-tracking {
  syntax: "*";
  inherits: false
}

@property --tw-ordinal {
  syntax: "*";
  inherits: false
}

@property --tw-slashed-zero {
  syntax: "*";
  inherits: false
}

@property --tw-numeric-figure {
  syntax: "*";
  inherits: false
}

@property --tw-numeric-spacing {
  syntax: "*";
  inherits: false
}

@property --tw-numeric-fraction {
  syntax: "*";
  inherits: false
}

@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-ring-color {
  syntax: "*";
  inherits: false
}

@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false
}

@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-ring-inset {
  syntax: "*";
  inherits: false
}

@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0;
}

@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}

@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}

@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}

@property --tw-blur {
  syntax: "*";
  inherits: false
}

@property --tw-brightness {
  syntax: "*";
  inherits: false
}

@property --tw-contrast {
  syntax: "*";
  inherits: false
}

@property --tw-grayscale {
  syntax: "*";
  inherits: false
}

@property --tw-hue-rotate {
  syntax: "*";
  inherits: false
}

@property --tw-invert {
  syntax: "*";
  inherits: false
}

@property --tw-opacity {
  syntax: "*";
  inherits: false
}

@property --tw-saturate {
  syntax: "*";
  inherits: false
}

@property --tw-sepia {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false
}

@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}

@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-blur {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-brightness {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-contrast {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-grayscale {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-invert {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-opacity {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-saturate {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-sepia {
  syntax: "*";
  inherits: false
}

@property --tw-duration {
  syntax: "*";
  inherits: false
}

@property --tw-ease {
  syntax: "*";
  inherits: false
}

@keyframes ping {
  75%, 100% {
    opacity: 0;
    transform: scale(2);
  }
}

@keyframes pulse {
  50% {
    opacity: .5;
  }
}

.ide-frame {
  background: var(--bg-grad, #0a0e1a);
  height: 100vh;
  overscroll-behavior: contain;
  grid-template-rows: auto auto 1fr;
  grid-template-columns: minmax(0, 1fr);
  height: 100dvh;
  display: grid;
  position: relative;
  overflow: hidden;
}

.ide-frame button, .ide-frame a, .ide-frame [role="button"] {
  touch-action: manipulation;
}

.ide-frame {
  --bg: #0b0f1c;
  --bg-grad: #0b0f1c;
  --solid-1: #11161f;
  --solid-2: #161c27;
  --solid-3: #1c2331;
  --solid-4: #232b3a;
  --surface: #ffffff0f;
  --surface-2: #ffffff1a;
  --surface-elev: #ffffff24;
  --border: #ffffff1a;
  --border-strong: #ffffff2e;
  --edge-hi: inset 0 0 0 1px #ffffff14;
  --fg: #e6edf3;
  --fg-2: #9ba6b3;
  --fg-3: #7d8694;
  --accent: #06b6d4;
  --accent-dark: #0e7490;
  --accent-2: #c026d3;
  --accent-glow: #06b6d466;
  --danger: #f87171;
  --warn: #fbbf24;
  --ok: #34d399;
  --radius: 24px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --radius-key: 14px;
  --blur: blur(24px) saturate(140%);
  --shadow-card: 0 8px 32px -8px #00000080;
  --shadow-key: 0 2px 0 #ffffff0a inset, 0 -2px 8px #0000004d;
  --font-ui: -apple-system, BlinkMacSystemFont, "SF Pro", "Inter", system-ui, sans-serif;
  --font-mono: "JBMonoIDE", "SF Mono", "JetBrains Mono", "Cascadia Code", ui-monospace, monospace;
  --t-short: .12s;
  --t-default: .2s;
  --t-long: .36s;
  --ease-out: cubic-bezier(0,0,.3,1);
  --ease-enter: cubic-bezier(.22,1,.36,1);
  --ease-exit: cubic-bezier(.4,0,1,1);
  --ease-sheet: cubic-bezier(.32,.72,0,1);
  --press-scale: .96;
  --ease-spring: cubic-bezier(.22,1,.36,1);
  --text-label: 13px;
  --text-body: 14px;
  --text-section: 16px;
  --text-panel: 18px;
  --text-title: 24px;
  --pane-gap: 12px;
  --pane-pad: 16px;
  --header-h: 56px;
  --row-h: 64px;
  --key-h: 56px;
  --key-w: 72px;
  --chip-h: 44px;
  --kb-inset: 0px;
  font-family: var(--font-ui);
  color: var(--fg);
}

.ide-frame .top-nav {
  background: var(--surface);
  -webkit-backdrop-filter: var(--blur);
  backdrop-filter: var(--blur);
  border-bottom: 1px solid var(--border);
  min-height: var(--header-h);
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  display: flex;
}

.ide-frame .nav-burger {
  border-radius: var(--radius-sm);
  min-width: 44px;
  min-height: 44px;
  color: var(--fg-2);
  background: var(--surface);
  justify-content: center;
  align-items: center;
  font-size: 20px;
  display: inline-flex;
}

.ide-frame .nav-brand {
  letter-spacing: -.01em;
  color: var(--fg);
  font-size: 15px;
  font-weight: 600;
  font-family: var(--font-mono);
  white-space: nowrap;
  text-overflow: ellipsis;
  flex: auto;
  min-width: 0;
  overflow: hidden;
}

.ide-frame .nav-spacer {
  flex: none;
}

.ide-frame .nav-pill {
  border-radius: var(--radius-sm);
  min-height: 44px;
  color: var(--fg-2);
  background: var(--surface);
  font-size: 13px;
  font-weight: 500;
  font-family: var(--font-mono);
  border: 1px solid #0000;
  align-items: center;
  padding: 0 16px;
  text-decoration: none;
  display: inline-flex;
}

.ide-frame .nav-pill-active {
  color: var(--accent);
  background: #06b6d41f;
  border-color: #06b6d44d;
}

.ide-frame .nav-avatar {
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: #fff;
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  min-width: 44px;
  min-height: 44px;
  font-size: 13px;
  font-weight: 600;
  display: inline-flex;
}

.ide-frame .session-ribbon {
  border-bottom: 1px solid var(--border);
  touch-action: pan-x;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  z-index: 8;
  background: none;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  display: none;
  position: relative;
  overflow: auto hidden;
  -webkit-mask-image: linear-gradient(to right, #0000 0, #000 16px calc(100% - 24px), #0000 100%);
  mask-image: linear-gradient(to right, #0000 0, #000 16px calc(100% - 24px), #0000 100%);
}

.ide-frame[data-view="ide"] .session-ribbon {
  display: flex;
}

.ide-frame .ribbon-chip-wrap {
  flex: none;
  align-items: stretch;
  gap: 12px;
  display: inline-flex;
}

.ide-frame .ribbon-chip {
  border-radius: var(--radius-sm);
  background: var(--surface);
  min-height: 44px;
  font-family: var(--font-mono);
  color: var(--fg-2);
  border: 1px solid #0000;
  flex: none;
  align-items: center;
  gap: 8px;
  padding: 0 14px;
  font-size: 13px;
  font-weight: 500;
  transition: transform 80ms, border-color .15s, background .15s, color .15s;
  display: inline-flex;
}

.ide-frame .ribbon-chip:active {
  transform: scale(.97);
}

.ide-frame .ribbon-chip[data-active="true"] {
  color: var(--accent);
  background: #06b6d41a;
  border-color: #06b6d447;
}

.ide-frame .ribbon-chip[data-state="working"] {
  color: var(--fg);
}

.ide-frame .ribbon-chip[data-active="true"][data-state="working"] {
  color: var(--accent);
}

.ide-frame .ribbon-chip[data-state="needs"] {
  color: var(--warn);
  border-color: #fbbf2459;
  animation: 1.5s ease-in-out infinite ribbonPulse;
}

.ide-frame .ribbon-chip[data-state="done"] {
  color: var(--ok);
}

@keyframes ribbonPulse {
  50% {
    border-color: #fbbf24b3;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .ribbon-chip[data-state="needs"] {
    animation: none;
  }
}

.ide-frame .ribbon-kill {
  border-radius: var(--radius-sm);
  color: #fca5a5;
  min-width: 44px;
  min-height: 44px;
  font-family: var(--font-mono);
  cursor: pointer;
  background: #f871711a;
  border: 1px solid #f8717152;
  justify-content: center;
  align-items: center;
  padding: 0 10px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1;
  transition: background .15s, border-color .15s, transform 80ms, color .15s;
  display: inline-flex;
}

.ide-frame .ribbon-kill:hover {
  color: #fecaca;
  background: #f8717129;
  border-color: #f8717173;
}

.ide-frame .ribbon-kill:active {
  transform: scale(.97);
}

.ide-frame .ribbon-kill:disabled {
  opacity: .5;
  cursor: not-allowed;
}

.ide-frame .ribbon-add {
  background: var(--accent);
  color: #031018;
  min-width: 44px;
  min-height: 44px;
  font-family: var(--font-mono);
  transition: transform var(--t-short) var(--ease-out), filter var(--t-short) var(--ease-out);
  border: 1px solid #0000;
  border-radius: 22px;
  justify-content: center;
  align-items: center;
  gap: 4px;
  margin-left: auto;
  padding: 0 14px;
  font-size: 14px;
  font-weight: 600;
  display: inline-flex;
  box-shadow: inset 0 1px #ffffff40;
}

.ide-frame .ribbon-add:hover {
  filter: brightness(1.08);
}

.ide-frame .ribbon-add:active {
  filter: brightness(.95);
  transform: scale(.97);
}

.ide-frame .ribbon-dot {
  border-radius: 50%;
  flex: none;
  width: 6px;
  height: 6px;
}

.ide-frame .ribbon-dot-working {
  background: var(--accent);
  box-shadow: 0 0 4px var(--accent);
}

.ide-frame .ribbon-dot-needs {
  background: var(--warn);
}

.ide-frame .ribbon-dot-done {
  background: var(--ok);
}

.ide-frame .ribbon-dim {
  color: var(--fg-3);
}

.ide-frame .ide-grid {
  gap: var(--pane-gap);
  padding: var(--pane-gap);
  background: var(--bg-grad);
  grid-template-columns: minmax(0, 1fr) minmax(0, 3fr) minmax(0, 1.8fr);
  min-width: 0;
  min-height: 0;
  display: grid;
  position: relative;
  overflow: hidden;
}

.ide-frame[data-orient="portrait"] .ide-grid {
  grid-template-rows: minmax(0, 1fr);
  grid-template-columns: minmax(0, 1fr);
  overflow: hidden;
}

.ide-frame[data-orient="portrait"] .tab-bar {
  display: flex;
}

.ide-frame[data-orient="portrait"] {
  grid-template-rows: auto auto auto 1fr;
}

.ide-frame[data-orient="portrait"][data-perm="bypass"] {
  grid-template-rows: auto auto auto auto 1fr;
}

.ide-frame[data-orient="portrait"][data-portrait-tab="tree"] .pane:not(.pane-tree), .ide-frame[data-orient="portrait"][data-portrait-tab="terminal"] .pane:not(.pane-term), .ide-frame[data-orient="portrait"][data-portrait-tab="keys"] .pane:not(.pane-prev) {
  display: none;
}

.ide-frame .tab-bar {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  gap: 12px;
  padding: 8px;
  display: none;
}

.ide-frame .tab-btn {
  border-radius: var(--radius-sm);
  min-height: 48px;
  color: var(--fg-2);
  font-size: 14px;
  font-weight: 500;
  font-family: var(--font-ui);
  background: none;
  flex: 1 1 0;
}

.ide-frame .tab-btn[aria-selected="true"] {
  background: var(--surface-2);
  color: var(--fg);
  box-shadow: 0 0 0 1px var(--border) inset;
}

.ide-frame .pane {
  background: var(--solid-1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  min-width: 0;
  min-height: 0;
  box-shadow: var(--shadow-card);
  flex-direction: column;
  display: flex;
  position: relative;
  overflow: hidden;
}

.ide-frame .pane-term {
  background: #121212;
}

.ide-frame .pane-prev {
  background: var(--surface);
  -webkit-backdrop-filter: var(--blur);
  backdrop-filter: var(--blur);
  box-shadow: var(--shadow-card), var(--edge-hi);
}

.ide-frame .pane[data-focused="true"] {
  box-shadow: inset 3px 0 0 var(--accent), var(--shadow-card), var(--edge-hi);
}

.ide-frame .pane.pane-tree[data-focused="true"], .ide-frame .pane.pane-prev[data-focused="true"] {
  background: var(--solid-2);
}

.ide-frame .pane.pane-prev[data-focused="true"] {
  background: var(--surface-2);
  -webkit-backdrop-filter: var(--blur);
  backdrop-filter: var(--blur);
}

.ide-frame .pane-prev .pane-title, .ide-frame .pane-keys .pane-title {
  font-family: var(--font-mono);
  letter-spacing: var(--track-eyebrow);
  text-transform: uppercase;
  color: var(--fg-3);
}

.ide-frame .pane-header {
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 12px 14px;
  display: flex;
}

.ide-frame .pane-title {
  font-size: var(--text-label);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--fg);
  white-space: nowrap;
  text-overflow: ellipsis;
  font-weight: 700;
  font-family: var(--font-ui);
  flex: auto;
  overflow: hidden;
}

.ide-frame .icon-btn {
  border-radius: var(--radius-sm);
  min-width: 44px;
  min-height: 44px;
  color: var(--fg-2);
  background: none;
  justify-content: center;
  align-items: center;
  padding: 0 8px;
  font-size: 16px;
  transition: background .15s, color .15s;
  display: inline-flex;
}

.ide-frame .icon-btn:hover {
  background: var(--surface-2);
  color: var(--fg);
}

.ide-frame .icon-btn:active {
  background: var(--surface-elev);
  transform: scale(var(--press-scale));
  transition: transform var(--t-short) var(--ease-out);
}

.ide-frame .dot {
  border-radius: 50%;
  flex: none;
  width: 8px;
  height: 8px;
}

.ide-frame .dot-ok {
  background: var(--ok);
  box-shadow: 0 0 8px var(--ok);
}

.ide-frame .agent-pill {
  min-height: 32px;
  font-family: var(--font-mono);
  font-size: var(--text-label);
  background: var(--surface);
  color: var(--fg);
  white-space: nowrap;
  border: 1px solid #0000;
  border-radius: 11px;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  display: inline-flex;
}

.ide-frame .agent-dot {
  background: var(--fg-3);
  border-radius: 50%;
  flex: none;
  width: 8px;
  height: 8px;
}

.ide-frame .agent-elapsed {
  color: var(--fg-2);
  font-variant-numeric: tabular-nums lining-nums;
}

.ide-frame .agent-pill[data-state="working"] {
  color: var(--accent);
  background: #06b6d41f;
  border-color: #06b6d44d;
}

.ide-frame .agent-pill[data-state="working"] .agent-dot {
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent);
}

.ide-frame .agent-pill[data-state="thinking"] {
  color: #c084fc;
  background: #c026d31f;
  border-color: #c026d34d;
}

.ide-frame .agent-pill[data-state="thinking"] .agent-dot {
  background: var(--accent-2);
  box-shadow: 0 0 6px var(--accent-2);
  animation: 1.3s ease-in-out infinite agentDotPulse;
}

.ide-frame .agent-pill[data-state="awaiting"] {
  color: var(--warn);
  background: #fbbf241f;
  border-color: #fbbf2459;
}

.ide-frame .agent-pill[data-state="awaiting"] .agent-dot {
  background: var(--warn);
  box-shadow: 0 0 6px var(--warn);
  animation: 1.3s ease-in-out infinite agentDotPulse;
}

.ide-frame .agent-pill[data-state="idle"] {
  color: var(--ok);
  background: #34d3991a;
  border-color: #34d3994d;
}

.ide-frame .agent-pill[data-state="idle"] .agent-dot {
  background: var(--ok);
  box-shadow: 0 0 6px var(--ok);
}

.ide-frame .agent-pill[data-state="error"] {
  color: var(--danger);
  background: #f871711f;
  border-color: #f8717159;
}

.ide-frame .agent-pill[data-state="error"] .agent-dot {
  background: var(--danger);
  box-shadow: 0 0 6px var(--danger);
}

.ide-frame .agent-pill[data-state="stale"] {
  color: var(--warn);
}

.ide-frame .agent-pill[data-state="stale"] .agent-dot {
  background: var(--fg-3);
}

@keyframes agentDotPulse {
  50% {
    opacity: .35;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .agent-pill .agent-dot {
    animation: none !important;
  }
}

.ide-frame .nav-drawer-overlay {
  z-index: 50;
  display: flex;
  position: fixed;
  inset: 0;
}

.ide-frame .nav-drawer-backdrop {
  background: #00000080;
  border: 0;
  position: absolute;
  inset: 0;
}

.ide-frame .nav-drawer {
  border-right: 1px solid var(--border-strong);
  width: 320px;
  max-width: 85vw;
  height: 100%;
  box-shadow: var(--shadow-card);
  background: #141828fa;
  flex-direction: column;
  display: flex;
  position: relative;
  overflow-y: auto;
}

.ide-frame .nav-drawer-head {
  color: var(--fg);
  border-bottom: 1px solid var(--border);
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px;
  font-size: 16px;
  font-weight: 700;
  display: flex;
}

.ide-frame .nav-drawer-close {
  min-width: 44px;
  min-height: 44px;
  color: var(--fg-2);
  background: none;
  border: 0;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  display: inline-flex;
}

.ide-frame .nav-drawer-row {
  min-height: 56px;
  font-family: var(--font-mono);
  color: var(--fg);
  text-align: left;
  background: none;
  border: 0;
  border-bottom: 1px solid #ffffff0d;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 0 16px;
  font-size: 14px;
  text-decoration: none;
  display: flex;
}

.ide-frame .nav-drawer-row:active {
  background: var(--surface-2);
}

.ide-frame .nav-drawer-row.active {
  color: var(--accent);
}

.ide-frame .nav-drawer-glyph {
  text-align: center;
  width: 20px;
  color: var(--fg-2);
  flex: none;
}

.ide-frame .nav-drawer-row.active .nav-drawer-glyph {
  color: var(--accent);
}

.ide-frame .nav-drawer-chev {
  color: var(--fg-3);
  margin-left: auto;
}

.ide-frame .nav-drawer-sep {
  background: var(--border);
  height: 1px;
  margin: 4px 0;
}

.ide-frame .ribbon-triage {
  min-height: 44px;
  font-family: var(--font-mono);
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--fg-2);
  border-radius: 999px;
  flex: none;
  align-items: center;
  gap: 7px;
  padding: 0 12px;
  font-size: 11.5px;
  display: inline-flex;
}

.ide-frame .ribbon-triage[data-needs="true"] {
  color: var(--warn);
  background: #fbbf241f;
  border-color: #fbbf2459;
}

.ide-frame .ribbon-triage-dot {
  border-radius: 50%;
  flex: none;
  width: 7px;
  height: 7px;
}

.ide-frame .ribbon-triage-dot.ok {
  background: var(--accent);
  box-shadow: 0 0 6px var(--accent);
}

.ide-frame .ribbon-triage-dot.needs {
  background: var(--warn);
  box-shadow: 0 0 6px var(--warn);
  animation: 1.3s ease-in-out infinite agentDotPulse;
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .ribbon-triage-dot.needs {
    animation: none;
  }
}

.ide-frame .ribbon-lock {
  text-align: center;
  flex: none;
  width: 16px;
  font-size: 12px;
}

.ide-frame .ribbon-lock-protected {
  color: var(--fg-2);
}

.ide-frame .ribbon-lock-locked {
  color: var(--accent);
}

.ide-frame .ribbon-lock-attached {
  color: var(--warn);
}

.ide-frame .ribbon-htag {
  text-transform: uppercase;
  letter-spacing: .05em;
  background: var(--surface-2);
  color: var(--fg-3);
  border-radius: 6px;
  flex: none;
  padding: 1px 6px;
  font-size: 12px;
}

.ide-frame .ribbon-htag-locked {
  color: var(--accent);
}

.ide-frame .ribbon-htag-attached {
  color: var(--warn);
}

.ribbon-sheet {
  width: 100%;
  max-width: 560px;
  padding: 12px 16px calc(16px + env(safe-area-inset-bottom));
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  backdrop-filter: blur(24px) saturate(140%);
  background: #141828f5;
  border: 1px solid #ffffff2e;
  border-bottom: 0;
  border-top-left-radius: 28px;
  border-top-right-radius: 28px;
  flex-direction: column;
  gap: 10px;
  display: flex;
  position: relative;
  box-shadow: 0 -20px 60px #0009;
}

.ribbon-sheet-grab {
  background: #ffffff40;
  border-radius: 2px;
  width: 48px;
  height: 4px;
  margin: 0 auto 4px;
}

.ribbon-sheet-head {
  flex-direction: column;
  gap: 2px;
  padding: 0 2px 4px;
  display: flex;
}

.ribbon-sheet-title {
  font-family: var(--font-mono);
  color: #e6edf3;
  word-break: break-all;
  font-size: 16px;
  font-weight: 700;
}

.ribbon-sheet-sub {
  color: #9ba6b3;
  font-size: 12px;
}

.ribbon-sheet-note {
  color: #9ba6b3;
  background: #ffffff0d;
  border: 1px solid #ffffff1f;
  border-radius: 16px;
  padding: 12px;
  font-size: 13px;
}

.ribbon-sheet-btn {
  width: 100%;
  min-height: 56px;
  font-family: var(--font-mono);
  color: #e6edf3;
  cursor: pointer;
  background: #ffffff0f;
  border: 1px solid #ffffff2e;
  border-radius: 18px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 600;
  transition: transform 80ms, filter .15s;
  display: inline-flex;
}

.ribbon-sheet-btn:active {
  transform: scale(.98);
}

.ribbon-sheet-btn:disabled {
  opacity: .6;
}

.ribbon-sheet-lock {
  color: var(--accent);
  background: #06b6d42e;
  border-color: #06b6d473;
}

.ribbon-sheet-unlock {
  color: #34d399;
  background: #34d39929;
  border-color: #34d39973;
}

.ribbon-sheet-kill {
  color: #fecaca;
  background: #f8717124;
  border-color: #f8717166;
}

.ribbon-sheet-cancel {
  color: var(--fg-3);
  background: #ffffff0a;
  border-color: #ffffff1f;
}

.ide-frame .ribbon-confirm {
  flex: none;
  align-items: center;
  gap: 12px;
  padding: 0 4px;
  display: inline-flex;
}

.ide-frame .ribbon-confirm-q {
  color: var(--danger);
  font-family: var(--font-mono);
  white-space: nowrap;
  align-items: center;
  padding: 0 8px;
  font-size: 12px;
  display: inline-flex;
}

.ide-frame .ribbon-confirm-yes, .ide-frame .ribbon-confirm-no {
  border-radius: var(--radius-sm);
  border: 1px solid #0000;
  justify-content: center;
  align-items: center;
  min-width: 44px;
  min-height: 44px;
  font-size: 14px;
  font-weight: 700;
  display: inline-flex;
}

.ide-frame .ribbon-confirm-yes {
  background: var(--danger);
  color: #2a0606;
}

.ide-frame .ribbon-confirm-no {
  background: var(--surface);
  color: var(--fg-2);
  border-color: var(--border);
}

.ide-frame .ribbon-toast {
  z-index: 40;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-strong);
  box-shadow: var(--shadow-card);
  font-family: var(--font-ui);
  color: var(--fg);
  background: #141828f7;
  align-items: center;
  gap: 14px;
  padding: 12px 16px 14px;
  font-size: 13px;
  display: inline-flex;
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
}

.ide-frame .ribbon-toast code {
  color: var(--accent);
  font-family: var(--font-mono);
}

.ide-frame .ribbon-toast-undo {
  border-radius: var(--radius-sm);
  min-height: 44px;
  color: var(--accent);
  background: #06b6d41f;
  border: 1px solid #06b6d44d;
  align-items: center;
  padding: 0 16px;
  font-size: 12.5px;
  font-weight: 700;
  display: inline-flex;
}

.ide-frame .ribbon-toast-bar {
  background: var(--accent);
  transform-origin: 0;
  border-radius: 2px;
  height: 2px;
  animation: 5s linear forwards ribbonToastBar;
  position: absolute;
  bottom: 6px;
  left: 12px;
  right: 12px;
}

@keyframes ribbonToastBar {
  from {
    transform: scaleX(1);
  }

  to {
    transform: scaleX(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .ribbon-toast-bar {
    animation: none;
  }
}

.ide-frame .shortcuts-rail, .ide-frame .collapse-shortcuts {
  display: none;
}

.ide-frame .shortcuts-rail {
  background: none;
  border: 0;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 12px;
  width: 100%;
  height: 100%;
  padding: 14px 0;
}

.ide-frame .shortcuts-rail-chev {
  color: var(--accent);
  font-size: 18px;
}

.ide-frame .shortcuts-rail-label {
  writing-mode: vertical-rl;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--fg-2);
  font-size: 11px;
  transform: rotate(180deg);
}

@media (min-width: 1500px) {
  .ide-frame[data-orient="landscape"] .collapse-shortcuts {
    display: inline-flex;
  }

  .ide-frame[data-orient="landscape"][data-shortcuts="collapsed"] .ide-grid {
    grid-template-columns: 220px minmax(0, 1fr) 44px;
  }

  .ide-frame[data-orient="landscape"][data-shortcuts="collapsed"] .pane-prev .pane-header, .ide-frame[data-orient="landscape"][data-shortcuts="collapsed"] .pane-prev .chip-row, .ide-frame[data-orient="landscape"][data-shortcuts="collapsed"] .pane-prev .mod-row, .ide-frame[data-orient="landscape"][data-shortcuts="collapsed"] .pane-prev .mod-cluster {
    display: none;
  }

  .ide-frame[data-orient="landscape"][data-shortcuts="collapsed"] .pane-prev .shortcuts-rail {
    display: flex;
  }
}

.ide-frame .term-composer {
  left: 8px;
  right: 8px;
  bottom: calc(8px + var(--kb-inset, 0px));
  z-index: 4;
  align-items: center;
  gap: 12px;
  display: flex;
  position: absolute;
}

.ide-frame .composer-btn {
  width: 44px;
  height: 44px;
  color: var(--fg-2);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #080c16b8;
  border: 1px solid #06b6d44d;
  border-radius: 10px;
  flex: none;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  display: inline-flex;
}

.ide-frame .composer-btn.listening {
  color: var(--danger);
  background: #f8717124;
  border-color: #f8717173;
  animation: 1.1s ease-in-out infinite agentDotPulse;
}

.ide-frame .composer-input {
  color: #e6edf3;
  caret-color: #06b6d4;
  min-width: 0;
  height: 44px;
  font-family: var(--font-mono);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #080c16b8;
  border: 1px solid #06b6d44d;
  border-radius: 10px;
  outline: none;
  flex: auto;
  padding: 0 14px;
  font-size: 16px;
}

.ide-frame .composer-input::placeholder {
  color: var(--fg-3);
}

.ide-frame .composer-send {
  background: var(--accent);
  color: #031018;
  min-height: 44px;
  transition: transform var(--t-short) var(--ease-out), filter var(--t-short) var(--ease-out);
  border: 0;
  border-radius: 10px;
  flex: none;
  align-items: center;
  padding: 0 16px;
  font-size: 13px;
  font-weight: 700;
  display: inline-flex;
  box-shadow: inset 0 1px #ffffff40;
}

.ide-frame .composer-send:active {
  transform: scale(var(--press-scale));
  filter: brightness(.95);
}

.ide-frame .term-onboard {
  text-align: center;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 14px;
  height: 100%;
  padding: 24px;
  display: flex;
  overflow: hidden auto;
}

.ide-frame .term-onboard-banner {
  font-family: var(--font-mono);
  opacity: .8;
  margin: 0 0 4px;
  font-size: 12px;
  line-height: 1.5;
}

.ide-frame .term-onboard-glyph {
  color: var(--fg-3);
  font-size: 34px;
}

.ide-frame .term-onboard-title {
  color: var(--fg);
  margin: 0;
  font-size: 17px;
}

.ide-frame .term-onboard-steps {
  font-family: var(--font-mono);
  color: var(--fg-2);
  text-align: left;
  flex-direction: column;
  gap: 8px;
  margin: 0;
  padding: 0;
  font-size: 12.5px;
  list-style: none;
  display: flex;
}

.ide-frame .term-onboard-steps li {
  align-items: center;
  gap: 8px;
  display: flex;
}

.ide-frame .term-onboard-n {
  width: 20px;
  height: 20px;
  color: var(--accent);
  background: #06b6d426;
  border-radius: 50%;
  flex: none;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  display: inline-flex;
}

.ide-frame .term-onboard-cta {
  background: var(--accent);
  color: #031018;
  min-height: 56px;
  transition: transform var(--t-short) var(--ease-out), filter var(--t-short) var(--ease-out);
  border: 0;
  border-radius: 14px;
  align-items: center;
  padding: 0 24px;
  font-size: 14px;
  font-weight: 700;
  display: inline-flex;
  box-shadow: inset 0 1px #ffffff40;
}

.ide-frame .term-onboard-cta:active {
  transform: scale(var(--press-scale));
  filter: brightness(.95);
}

.ide-frame .term-approval {
  left: 8px;
  right: 8px;
  bottom: calc(64px + var(--kb-inset, 0px));
  z-index: 7;
  border-radius: var(--radius-md);
  -webkit-backdrop-filter: var(--blur);
  backdrop-filter: var(--blur);
  box-shadow: var(--shadow-card);
  background: #141828f5;
  border: 1px solid #fbbf2473;
  padding: 12px 14px;
  position: absolute;
}

.ide-frame .term-approval-h {
  font-family: var(--font-mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--warn);
  align-items: center;
  gap: 8px;
  font-size: 10.5px;
  font-weight: 700;
  display: flex;
}

.ide-frame .dot-warn {
  background: var(--warn);
  box-shadow: 0 0 8px var(--warn);
  animation: 1.3s ease-in-out infinite agentDotPulse;
}

.ide-frame .term-approval-action {
  font-family: var(--font-mono);
  color: var(--fg);
  border-left: 3px solid var(--accent);
  background: #0006;
  border-radius: 10px;
  align-items: center;
  gap: 9px;
  margin: 10px 0;
  padding: 9px 12px;
  font-size: 12.5px;
  display: flex;
  overflow: hidden;
}

.ide-frame .term-approval[data-destructive="true"] .term-approval-action {
  border-left-color: var(--danger);
}

.ide-frame .term-approval-badge {
  color: var(--accent);
  background: #06b6d42e;
  border-radius: 8px;
  flex: none;
  padding: 2px 8px;
  font-size: 12px;
  font-weight: 700;
}

.ide-frame .term-approval-target {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.ide-frame .term-approval-acts {
  gap: 12px;
  display: flex;
}

.ide-frame .term-appr-yes, .ide-frame .term-appr-no, .ide-frame .term-appr-always {
  min-height: 52px;
  font-family: var(--font-ui);
  border-radius: 13px;
  justify-content: center;
  align-items: center;
  gap: 6px;
  padding: 0 16px;
  font-size: 13px;
  font-weight: 700;
  display: inline-flex;
}

.ide-frame .term-appr-yes {
  background: var(--ok);
  color: #04130c;
  flex: 2 1 0;
  box-shadow: 0 0 16px #34d39959;
}

.ide-frame .term-appr-no {
  color: var(--danger);
  background: #f871712e;
  border: 1px solid #f8717173;
  flex: 1 1 0;
}

.ide-frame .term-appr-always {
  background: var(--surface);
  border: 1px solid var(--border-strong);
  color: var(--fg-2);
  flex: 1 1 0;
  font-weight: 600;
}

.ide-frame .term-appr-yes:disabled, .ide-frame .term-appr-no:disabled, .ide-frame .term-appr-always:disabled {
  opacity: .45;
}

.ide-frame .term-appr-always[data-armed="true"] {
  color: var(--warn);
  background: #fbbf2429;
  border-color: #fbbf2499;
  animation: 1.1s ease-in-out infinite ribbonPulse;
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .term-appr-always[data-armed="true"] {
    animation: none;
  }
}

.ide-frame .term-conn {
  z-index: 6;
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  background: #0a0e1a8c;
  justify-content: center;
  align-items: center;
  display: flex;
  position: absolute;
  inset: 0;
}

.ide-frame .term-conn-card {
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  text-align: center;
  background: #141828f0;
  border: 1px solid #06b6d44d;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  max-width: 80%;
  padding: 16px 20px;
  display: flex;
}

.ide-frame .term-conn-card.offline {
  border-color: #fbbf2466;
}

.ide-frame .term-conn-glyph {
  color: var(--warn);
  font-size: 22px;
}

.ide-frame .term-conn-title {
  color: var(--accent);
  font-size: 13px;
}

.ide-frame .term-conn-card.offline .term-conn-title {
  color: var(--warn);
}

.ide-frame .term-conn-sub {
  color: var(--fg-2);
  font-size: 12px;
}

.ide-frame .term-retry {
  border-radius: var(--radius-sm);
  min-height: 44px;
  color: var(--accent);
  font-family: var(--font-mono);
  transition: transform var(--t-short) var(--ease-out), filter var(--t-short) var(--ease-out);
  background: #06b6d42e;
  border: 1px solid #06b6d473;
  align-items: center;
  margin-top: 4px;
  padding: 0 16px;
  font-size: 12px;
  display: inline-flex;
}

.ide-frame .term-retry:active {
  transform: scale(var(--press-scale));
  filter: brightness(.95);
}

.ide-frame .term-spinner {
  border: 2px solid var(--border-strong);
  border-top-color: var(--accent);
  border-radius: 50%;
  width: 20px;
  height: 20px;
  animation: .9s linear infinite termSpin;
}

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

.ide-frame .term-skeleton {
  padding: 4px 0;
  display: block;
}

.ide-frame .term-skeleton .term-skel-line, .ide-frame .ide-skeleton-line {
  border-radius: var(--radius-sm);
  background: #ffffff14 linear-gradient(90deg, #ffffff0a, #ffffff29, #ffffff0a) 0 0 / 200% 100%;
  height: 12px;
  margin: 8px 0;
  animation: 1.4s linear infinite termShim;
  display: block;
}

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

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

@media (prefers-reduced-motion: reduce) {
  .ide-frame .term-spinner, .ide-frame .term-skel-line, .ide-frame .ide-skeleton-line {
    animation: none !important;
  }
}

.ide-frame .ide-inline-warn, .ide-frame .ide-inline-danger {
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: var(--text-label);
  border: 1px solid #0000;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  line-height: 1.4;
  display: flex;
}

.ide-frame .ide-inline-warn {
  color: var(--warn);
  background: #fbbf241f;
  border-color: #fbbf2440;
}

.ide-frame .ide-inline-danger {
  color: var(--danger);
  background: #f871711f;
  border-color: #f8717140;
}

.ide-frame .pane-term .pane-header {
  position: relative;
}

.ide-frame .term-esc {
  border-radius: var(--radius-sm);
  min-width: 44px;
  min-height: 44px;
  font-family: var(--font-mono);
  color: var(--fg-2);
  background: var(--surface);
  border: 1px solid var(--border-strong);
  flex: none;
  justify-content: center;
  align-items: center;
  padding: 0 11px;
  font-size: 12px;
  display: inline-flex;
}

.ide-frame .term-stop {
  border-radius: var(--radius-sm);
  min-width: 44px;
  min-height: 44px;
  font-family: var(--font-mono);
  color: var(--danger);
  background: #f8717129;
  border: 1px solid #f8717173;
  flex: none;
  justify-content: center;
  align-items: center;
  gap: 6px;
  padding: 0 12px;
  font-size: 12px;
  font-weight: 700;
  transition: transform 60ms, background .12s;
  display: inline-flex;
}

.ide-frame .term-stop:active {
  background: #f8717147;
  transform: translateY(1px);
}

.ide-frame .term-esc:disabled, .ide-frame .term-stop:disabled {
  opacity: .4;
}

.ide-frame .term-menu-backdrop {
  z-index: 30;
  background: none;
  border: 0;
  position: fixed;
  inset: 0;
}

.ide-frame .term-menu {
  z-index: 31;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  min-width: 230px;
  box-shadow: var(--shadow-card);
  background: #141828f7;
  flex-direction: column;
  display: flex;
  position: absolute;
  top: calc(100% + 6px);
  right: 8px;
  overflow: hidden;
}

.ide-frame .term-menu-row {
  text-align: left;
  width: 100%;
  min-height: 48px;
  font-family: var(--font-mono);
  color: var(--fg);
  background: none;
  border: 0;
  border-bottom: 1px solid #ffffff0d;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  font-size: 13px;
  display: flex;
}

.ide-frame .term-menu-row:active {
  background: var(--surface-2);
}

.ide-frame .term-menu-row.danger {
  color: var(--danger);
}

.ide-frame .term-menu-row.danger:active {
  background: #f871711a;
}

.ide-frame .term-menu-enc {
  color: var(--fg-3);
  margin-left: auto;
  font-size: 12px;
}

.ide-frame .term-status {
  font-family: var(--font-mono);
  color: var(--fg-2);
  white-space: nowrap;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  display: inline-flex;
}

.ide-frame .tree-quick-strip {
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  -webkit-overflow-scrolling: touch;
  touch-action: pan-x;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  align-items: center;
  gap: 10px;
  min-height: 56px;
  padding: 8px 10px;
  display: flex;
  overflow: auto hidden;
  -webkit-mask-image: linear-gradient(to right, #0000 0, #000 16px calc(100% - 24px), #0000 100%);
  mask-image: linear-gradient(to right, #0000 0, #000 16px calc(100% - 24px), #0000 100%);
}

.ide-frame .tree-quick-chip {
  border-radius: var(--radius-sm);
  background: var(--surface);
  border: 1px solid var(--border);
  min-width: 44px;
  min-height: 44px;
  color: var(--fg-2);
  font-family: var(--font-mono);
  white-space: nowrap;
  flex: none;
  justify-content: center;
  align-items: center;
  gap: 6px;
  max-width: 220px;
  padding: 0 12px;
  font-size: 12px;
  transition: background .15s, color .15s, border-color .15s, transform 80ms;
  display: inline-flex;
}

.ide-frame .tree-quick-chip:hover {
  background: var(--surface-2);
  color: var(--fg);
  border-color: var(--border-strong);
}

.ide-frame .tree-quick-chip:active {
  transform: scale(.97);
}

.ide-frame .tree-quick-chip[data-pinned="true"] {
  color: var(--warn);
  background: #fbbf240f;
  border-color: #fbbf244d;
}

.ide-frame .tree-quick-wrap {
  flex: none;
  align-items: stretch;
  display: inline-flex;
}

.ide-frame .tree-quick-wrap .tree-quick-chip {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.ide-frame .tree-quick-unpin {
  border-top-right-radius: var(--radius-sm);
  border-bottom-right-radius: var(--radius-sm);
  min-width: 44px;
  min-height: 44px;
  color: var(--fg-3);
  cursor: pointer;
  background: #fbbf240f;
  border: 1px solid #fbbf244d;
  border-left: 0;
  flex: none;
  justify-content: center;
  align-items: center;
  padding: 0 8px;
  transition: background .12s, color .12s, transform 80ms;
  display: inline-flex;
}

.ide-frame .tree-quick-unpin:hover {
  color: #fca5a5;
  background: #f8717124;
}

.ide-frame .tree-quick-unpin:active {
  transform: scale(.96);
}

.ide-frame .tree-quick-icon {
  opacity: .85;
  flex: none;
  font-size: 12px;
}

.ide-frame .tree-quick-label {
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 180px;
  overflow: hidden;
}

.ide-frame .tree-crumbs {
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  align-items: center;
  gap: 6px;
  min-height: 56px;
  padding: 8px 10px 8px 8px;
  display: flex;
}

.ide-frame .tree-crumb-up {
  border-radius: var(--radius-sm);
  background: var(--surface);
  border: 1px solid var(--border);
  min-width: 44px;
  min-height: 44px;
  color: var(--fg-2);
  font-family: var(--font-mono);
  flex: none;
  justify-content: center;
  align-items: center;
  font-size: 18px;
  line-height: 1;
  transition: background .15s, color .15s, transform 80ms;
  display: inline-flex;
}

.ide-frame .tree-crumb-up:hover {
  background: var(--surface-2);
  color: var(--fg);
}

.ide-frame .tree-crumb-up:active {
  transform: scale(.95);
}

.ide-frame .tree-crumb-up:disabled {
  opacity: .35;
  cursor: not-allowed;
}

.ide-frame .tree-crumb-scroll {
  -webkit-overflow-scrolling: touch;
  touch-action: pan-x;
  overscroll-behavior: contain;
  white-space: nowrap;
  scrollbar-width: thin;
  flex: auto;
  align-items: center;
  gap: 0;
  min-width: 0;
  display: flex;
  overflow: auto hidden;
  -webkit-mask-image: linear-gradient(to right, #0000 0, #000 16px calc(100% - 24px), #0000 100%);
  mask-image: linear-gradient(to right, #0000 0, #000 16px calc(100% - 24px), #0000 100%);
}

.ide-frame .tree-crumb-row {
  flex: none;
  align-items: center;
  display: inline-flex;
}

.ide-frame .tree-crumb {
  border-radius: var(--radius-sm);
  min-width: 44px;
  min-height: 44px;
  color: var(--fg-2);
  font-family: var(--font-mono);
  background: none;
  border: 1px solid #0000;
  justify-content: center;
  align-items: center;
  padding: 0 12px;
  font-size: 13px;
  line-height: 1;
  transition: background .15s, color .15s, border-color .15s;
  display: inline-flex;
}

.ide-frame .tree-crumb:hover, .ide-frame .tree-crumb:active {
  background: var(--surface);
  color: var(--fg);
}

.ide-frame .tree-crumb[data-active="true"] {
  color: var(--accent);
  background: #06b6d41a;
  border-color: #06b6d447;
}

.ide-frame .tree-crumb-sep {
  color: var(--fg-3);
  font-family: var(--font-mono);
  -webkit-user-select: none;
  user-select: none;
  padding: 0 2px;
  font-size: 13px;
}

.ide-frame .tree-search {
  border-bottom: 1px solid var(--border);
  padding: 10px 12px;
}

.ide-frame .tree-search input {
  border-radius: var(--radius-sm);
  background: var(--surface-2);
  border: 1px solid var(--border);
  width: 100%;
  height: 44px;
  color: var(--fg);
  font-size: 16px;
  font-family: var(--font-ui);
  padding: 0 14px;
}

.ide-frame .tree-search input::placeholder {
  color: var(--fg-3);
}

.ide-frame .tree {
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
  overscroll-behavior: contain;
  flex: auto;
  min-height: 0;
  padding: 6px 0 96px;
  overflow: hidden auto;
}

.ide-frame .tree-row-wrap {
  align-items: stretch;
  width: 100%;
  display: flex;
}

.ide-frame .tree-row {
  min-height: var(--row-h);
  color: var(--fg);
  font-size: 14px;
  font-family: var(--font-mono);
  cursor: pointer;
  text-align: left;
  background: none;
  border: 0;
  flex: auto;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 0 12px;
  transition: background .12s;
  display: flex;
  position: relative;
}

.ide-frame .tree-row-kebab {
  min-width: 44px;
  min-height: 44px;
  color: var(--fg-3);
  cursor: pointer;
  background: none;
  border: 0;
  flex: none;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  transition: background .12s, color .12s;
  display: inline-flex;
}

.ide-frame .tree-row-kebab:hover {
  background: var(--surface-2);
  color: var(--fg);
}

.ide-frame .tree-row-kebab:active {
  background: var(--surface-elev);
}

.ide-frame .tree-row:hover {
  background: var(--surface-2);
}

.ide-frame .tree-row:active {
  background: var(--surface-elev);
}

.ide-frame .tree-row[data-active="true"] {
  box-shadow: inset 3px 0 0 var(--accent);
  background: #06b6d41a;
}

.ide-frame .tree-chevron {
  min-width: 28px;
  min-height: 44px;
  color: var(--fg-3);
  background: none;
  border: 0;
  flex: none;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  transition: transform .15s;
  display: inline-flex;
}

.ide-frame .tree-row[data-collapsed="true"] .tree-chevron {
  transform: rotate(-90deg);
}

.ide-frame .tree-row[data-leaf="true"] .tree-chevron {
  visibility: hidden;
}

.ide-frame .tree-icon {
  text-align: center;
  flex: none;
  width: 20px;
  font-size: 14px;
}

.ide-frame .tree-name {
  white-space: nowrap;
  text-overflow: ellipsis;
  flex: auto;
  overflow: hidden;
}

.ide-frame .tree-badge {
  min-width: 18px;
  height: 18px;
  font-size: 12px;
  font-weight: 700;
  font-family: var(--font-mono);
  border-radius: 9px;
  flex: none;
  justify-content: center;
  align-items: center;
  margin-left: auto;
  padding: 0 6px;
  display: inline-flex;
}

.ide-frame .badge-M {
  color: var(--warn);
  background: #fbbf242e;
}

.ide-frame .badge-A {
  color: var(--ok);
  background: #34d3992e;
}

.ide-frame .badge-D {
  color: var(--danger);
  background: #f871712e;
}

.ide-frame .badge-Q {
  color: var(--fg-2);
  background: #8b949e2e;
}

.ide-frame .tree-row[data-depth="0"] {
  padding-left: 12px;
}

.ide-frame .tree-row[data-depth="1"] {
  padding-left: 28px;
}

.ide-frame .tree-row[data-depth="2"] {
  padding-left: 44px;
}

.ide-frame .tree-row[data-depth="3"] {
  padding-left: 60px;
}

.ide-frame .tree-row[data-depth="4"] {
  padding-left: 76px;
}

.ide-frame .term {
  background: var(--surface);
  overscroll-behavior: contain;
  touch-action: manipulation;
  flex: auto;
  min-height: 0;
  padding: 16px 20px;
  position: relative;
  overflow: hidden;
}

.ide-frame .term[data-live="true"] {
  background: linear-gradient(180deg, #070b14 0%, var(--bg) 100%);
}

.ide-frame .pane-term:has(.term[data-live="true"]) {
  box-shadow: 0 0 0 1px #06b6d42e, var(--shadow-card);
}

.ide-frame .term-xterm {
  box-sizing: border-box;
  touch-action: pan-y;
  overscroll-behavior: contain;
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}

.ide-frame .term-xterm[data-select-mode="true"] {
  touch-action: none;
}

.ide-frame .term-xterm[data-select-mode="true"] .xterm-rows, .ide-frame .term-xterm[data-select-mode="true"] .xterm-screen {
  -webkit-user-select: text;
  user-select: text;
}

.ide-frame .term-xterm[data-select-mode="true"] {
  box-shadow: inset 0 0 0 2px #22d3ee8c;
}

.ide-frame .term-xterm .xterm {
  box-sizing: border-box;
  height: 100%;
  padding: 0 0 56px;
}

.ide-frame .term-xterm .xterm-viewport {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  background-color: #121212 !important;
}

.ide-frame .term-xterm .xterm-viewport::-webkit-scrollbar {
  width: 10px;
}

.ide-frame .term-xterm .xterm-viewport::-webkit-scrollbar-thumb {
  background: #94a3b866;
  border-radius: 6px;
}

html, .xterm, .xterm * {
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

.xterm .xterm-rows, .xterm-width-cache-measure-container, .xterm-char-measure-element {
  font-variant-ligatures: none;
  font-feature-settings: "liga" 0, "clig" 0, "calt" 0, "dlig" 0;
}

.ide-frame .term-jump-live {
  left: 50%;
  bottom: calc(64px + var(--kb-inset, 0px));
  border-radius: var(--radius-sm);
  min-width: 88px;
  min-height: 44px;
  color: var(--accent);
  font-family: var(--font-mono);
  z-index: 10;
  background: linear-gradient(#06b6d438, #06b6d40f);
  border: 1px solid #06b6d473;
  justify-content: center;
  align-items: center;
  padding: 0 14px;
  font-size: 12px;
  font-weight: 600;
  display: inline-flex;
  position: absolute;
  transform: translateX(-50%);
  box-shadow: 0 4px 18px #06b6d44d;
}

.ide-frame .term-jump-live:active {
  transform: translateX(-50%) scale(.96);
}

.ide-frame .term-tools {
  z-index: 9;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 12px;
  max-width: calc(100% - 120px);
  display: flex;
  position: absolute;
  top: 8px;
  left: 12px;
}

.ide-frame .term-tool {
  border-radius: var(--radius-sm);
  min-height: 44px;
  color: var(--fg-2);
  font-family: var(--font-mono);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #080c16d1;
  border: 1px solid #06b6d44d;
  align-items: center;
  gap: 6px;
  padding: 0 12px;
  font-size: 12px;
  font-weight: 600;
  transition: background .12s, border-color .12s, transform 80ms, color .12s;
  display: inline-flex;
}

.ide-frame .term-tool:active {
  transform: scale(.96);
}

.ide-frame .term-tool[data-on="true"] {
  color: var(--accent);
  background: #06b6d433;
  border-color: #06b6d48c;
}

.ide-frame .term-copy-hint {
  z-index: 11;
  border-radius: var(--radius-sm);
  color: var(--accent);
  font-family: var(--font-mono);
  box-shadow: var(--shadow-card);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  pointer-events: none;
  white-space: nowrap;
  background: #080c16eb;
  border: 1px solid #06b6d466;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 600;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.ide-frame .term-type-hint {
  left: 8px;
  bottom: calc(64px + var(--kb-inset, 0px));
  z-index: 6;
  max-width: calc(100% - 16px);
  min-height: 44px;
  color: var(--fg-2);
  font-family: var(--font-mono);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  background: #080c16db;
  border: 1px dashed #06b6d473;
  border-radius: 22px;
  align-items: center;
  gap: 8px;
  padding: 0 16px;
  font-size: 12px;
  font-weight: 600;
  animation: 2.4s ease-in-out infinite agentDotPulse;
  display: inline-flex;
  position: absolute;
}

.ide-frame .term-type-hint:active {
  transform: scale(.97);
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .term-type-hint {
    animation: none;
  }
}

.ide-frame .t-ok {
  color: var(--ok);
}

.ide-frame .t-warn {
  color: var(--warn);
}

.ide-frame .t-acc {
  color: var(--accent);
}

.ide-frame .t-acc2 {
  color: var(--accent-2);
}

.ide-frame .t-dim {
  color: var(--fg-3);
}

.ide-frame .t-tool {
  color: var(--accent);
  font-weight: 600;
}

.ide-frame .t-danger {
  color: var(--danger);
}

.ide-frame .t-fg {
  color: var(--fg);
}

.ide-frame .term-cursor {
  background: var(--accent);
  vertical-align: text-bottom;
  width: 8px;
  height: 16px;
  animation: 1s steps(2, end) infinite blink;
  display: inline-block;
}

@keyframes blink {
  50% {
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .term-cursor {
    animation: none;
  }
}

.ide-frame .preview {
  background: var(--solid-1);
  touch-action: pan-x pan-y;
  flex: auto;
  padding: 16px;
  overflow: auto;
}

.ide-frame .preview-mock {
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  display: grid;
}

.ide-frame .mock-card {
  border-radius: var(--radius-md);
  background: var(--solid-2);
  border: 1px solid var(--border);
  box-shadow: var(--edge-hi);
  min-height: 96px;
  color: inherit;
  flex-direction: column;
  gap: 6px;
  padding: 18px;
  text-decoration: none;
  display: flex;
  position: relative;
  overflow: hidden;
}

.ide-frame .mock-card b {
  font-size: var(--text-label);
  color: var(--fg-2);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 700;
  font-family: var(--font-mono);
}

.ide-frame .mock-card span {
  color: var(--fg-2);
  font-size: 11px;
}

.ide-frame .mock-card .mock-num {
  letter-spacing: -.02em;
  font-size: 28px;
  font-weight: 700;
  font-family: var(--font-mono);
  color: var(--fg);
  font-variant-numeric: tabular-nums lining-nums;
  margin-top: auto;
}

.ide-frame .mock-card.span2 {
  grid-column: span 2;
}

.ide-frame .mock-card.mock-skill {
  background: color-mix(in srgb, var(--accent) 12%, var(--solid-2));
}

.ide-frame .mock-sparkline {
  opacity: .5;
  height: 28px;
  color: var(--fg-2);
}

.ide-frame .chip-row {
  border-top: 1px solid var(--border);
  background: var(--surface);
  flex-wrap: wrap;
  flex: none;
  align-content: flex-start;
  gap: 12px;
  padding: 10px 12px;
  display: flex;
}

.ide-frame .chip {
  min-height: var(--chip-h);
  min-width: 44px;
  font-family: var(--font-mono);
  color: var(--fg);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 22px;
  flex: none;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 500;
  transition: background .12s, transform 80ms, border-color .12s;
  display: inline-flex;
}

.ide-frame .chip:active {
  transform: scale(var(--press-scale));
  background: color-mix(in srgb, var(--accent) 18%, var(--surface-2));
}

.ide-frame .chip[data-pin="true"] {
  color: var(--accent);
  background: #06b6d42e;
  border-color: #06b6d466;
}

.ide-frame .chip[data-destructive="true"] {
  color: #fca5a5;
  border-color: #f8717152;
}

.ide-frame .chip[data-armed="true"] {
  color: #fecaca;
  background: #f8717133;
  border-color: #f87171a6;
  animation: 1.1s ease-in-out infinite ribbonPulse;
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .chip[data-armed="true"] {
    animation: none;
  }
}

.ide-frame .mod-row {
  background: var(--surface-2);
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
  flex: none;
  align-content: flex-start;
  gap: 12px;
  padding: 10px 12px;
  display: flex;
}

.ide-frame .mod-cluster {
  background: var(--surface-2);
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
  flex: none;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  display: flex;
}

.ide-frame .arrow-tri {
  grid-template-columns: repeat(3, minmax(52px, 1fr));
  grid-template-areas: ". up ."
                       "left down right";
  grid-auto-rows: 44px;
  gap: 12px;
  display: grid;
}

.ide-frame .arrow-tri .key {
  width: 100%;
  min-width: 0;
}

.ide-frame .arrow-tri .key[data-key="Up"] {
  grid-area: up;
}

.ide-frame .arrow-tri .key[data-key="Left"] {
  grid-area: left;
}

.ide-frame .arrow-tri .key[data-key="Down"] {
  grid-area: down;
}

.ide-frame .arrow-tri .key[data-key="Right"] {
  grid-area: right;
}

.ide-frame .key.key-enter {
  min-width: 64px;
  min-height: 92px;
  padding: 0 14px;
  font-size: 18px;
}

.ide-frame .key {
  border-radius: var(--radius-key);
  min-width: 52px;
  min-height: 44px;
  font-family: var(--font-mono);
  color: var(--fg);
  background: var(--surface);
  border: 1px solid var(--border-strong);
  box-shadow: var(--shadow-key);
  transition: transform var(--t-default) var(--ease-spring), background var(--t-short) var(--ease-out);
  flex: none;
  justify-content: center;
  align-items: center;
  gap: 4px;
  padding: 0 8px;
  font-size: 13px;
  font-weight: 600;
  display: inline-flex;
  position: relative;
}

.ide-frame .key:active {
  transform: translateY(2px) scale(var(--press-scale));
  background: var(--surface-elev);
  box-shadow: none;
  transition: transform var(--t-short) var(--ease-out), background var(--t-short) var(--ease-out);
}

.ide-frame .key[data-danger="true"] {
  color: var(--danger);
}

.ide-frame .key[data-accent="true"] {
  color: var(--accent);
}

.ide-frame .key[data-wide="true"] {
  min-width: calc(var(--key-w) * 1.5);
}

.ide-frame .key[data-toggled="true"] {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  box-shadow: 0 0 12px var(--accent-glow);
}

.ide-frame .key[data-ctrl-state="armed"] {
  color: var(--accent);
  box-shadow: 0 0 6px var(--accent-glow);
  background: #06b6d42e;
  border-color: #06b6d473;
  animation: 1s ease-in-out infinite ctrlArmed;
}

.ide-frame .key[data-ctrl-state="sticky"] {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  box-shadow: 0 0 14px var(--accent-glow);
}

@keyframes ctrlArmed {
  50% {
    box-shadow: 0 0 12px var(--accent-glow);
  }
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .key[data-ctrl-state="armed"] {
    animation: none;
  }
}

.ide-frame .fab-add {
  z-index: 12;
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: #fff;
  min-width: 64px;
  min-height: 64px;
  transition: transform var(--t-short) var(--ease-out), box-shadow var(--t-short) var(--ease-out);
  border: 0;
  border-radius: 22px;
  align-items: center;
  gap: 8px;
  padding: 0 22px;
  font-size: 15px;
  font-weight: 700;
  display: inline-flex;
  position: absolute;
  bottom: 24px;
  right: 24px;
  box-shadow: 0 12px 32px -8px #0000008c, inset 0 1px #ffffff40;
}

.ide-frame .fab-add:active {
  transform: scale(.95);
}

.ide-frame .fab-add-plus {
  font-size: 22px;
  line-height: 1;
}

.ide-frame .palette-fab {
  z-index: 9;
  background: var(--surface-elev);
  min-width: 56px;
  min-height: 56px;
  -webkit-backdrop-filter: var(--blur);
  backdrop-filter: var(--blur);
  border: 1px solid var(--border-strong);
  color: var(--fg);
  box-shadow: 0 8px 24px #0006, var(--edge-hi);
  transition: transform var(--t-short) var(--ease-out);
  border-radius: 28px;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  display: inline-flex;
  position: fixed;
  bottom: 24px;
  right: 88px;
}

.ide-frame .palette-fab:active {
  transform: scale(.95);
}

@media (min-width: 601px) {
  .ide-frame[data-orient="portrait"][data-portrait-tab="tree"] .palette-fab, .ide-frame[data-orient="portrait"][data-portrait-tab="terminal"] .palette-fab {
    bottom: 104px;
  }
}

.ide-frame .perm-banner {
  border-radius: var(--radius-sm);
  color: var(--fg);
  background: #f871711f;
  border: 1px solid #f8717166;
  align-items: flex-start;
  gap: 12px;
  margin: 10px 16px 0;
  padding: 14px 16px;
  font-size: 13px;
  display: none;
}

.ide-frame[data-perm="bypass"] .perm-banner {
  display: flex;
}

.ide-frame .perm-banner-icon {
  color: var(--danger);
  flex: none;
  font-size: 20px;
}

.ide-frame .perm-banner-body {
  flex: 1;
  line-height: 1.45;
}

.ide-frame .perm-banner-body b {
  color: var(--danger);
}

@media (min-width: 1100px) and (max-width: 1499px) and (orientation: landscape) {
  .ide-frame[data-orient="landscape"] .ide-grid {
    grid-template-columns: 200px minmax(0, 1fr) 340px;
  }

  .ide-frame .chip {
    padding: 0 10px;
    font-size: 12px;
  }

  .ide-frame .chip-row, .ide-frame .mod-row {
    gap: 8px;
    padding: 8px 10px;
  }

  .ide-frame .key {
    min-width: 48px;
    padding: 0 6px;
    font-size: 12px;
  }

  .ide-frame .tree-row {
    min-height: 48px;
    font-size: 13px;
  }

  .ide-frame .tree-quick-chip {
    max-width: 160px;
  }

  .ide-frame .tree-quick-label {
    max-width: 120px;
  }
}

@media (min-width: 700px) and (max-width: 1099px) and (orientation: landscape) {
  .ide-frame[data-orient="landscape"] .ide-grid {
    grid-template: "tree term" minmax(0, 1fr)
                   "keys keys"
                   / 180px minmax(0, 1fr);
  }

  .ide-frame[data-orient="landscape"] .pane-tree {
    grid-area: tree;
  }

  .ide-frame[data-orient="landscape"] .pane-term {
    grid-area: term;
  }

  .ide-frame[data-orient="landscape"] .pane-prev, .ide-frame[data-orient="landscape"] .pane-keys {
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    grid-area: keys;
    min-height: 220px;
    max-height: min(360px, 40vh);
    overflow-y: auto;
  }

  .ide-frame .palette-fab {
    bottom: calc(min(360px, 40vh) + 84px);
    right: 16px;
  }

  .ide-frame .pane-prev .pane-header {
    min-height: 36px;
    padding: 6px 12px;
  }

  .ide-frame .pane-prev .pane-title {
    font-size: 12px;
  }

  .ide-frame .chip {
    min-height: 44px;
    padding: 0 9px;
    font-size: 12px;
  }

  .ide-frame .chip-row, .ide-frame .mod-row, .ide-frame .mod-cluster {
    gap: 8px;
    padding: 6px 8px;
  }

  .ide-frame .key {
    min-width: 48px;
    min-height: 44px;
    padding: 0 6px;
    font-size: 12px;
  }

  .ide-frame .arrow-tri {
    grid-auto-rows: 44px;
    gap: 12px;
  }

  .ide-frame .key.key-enter {
    min-height: 84px;
  }

  .ide-frame .tree-row {
    min-height: 44px;
    padding: 0 8px;
    font-size: 12px;
  }

  .ide-frame .tree-row[data-depth="0"] {
    padding-left: 8px;
  }

  .ide-frame .tree-row[data-depth="1"] {
    padding-left: 20px;
  }

  .ide-frame .tree-row[data-depth="2"] {
    padding-left: 32px;
  }

  .ide-frame .tree-row[data-depth="3"] {
    padding-left: 44px;
  }

  .ide-frame .tree-row[data-depth="4"] {
    padding-left: 56px;
  }

  .ide-frame .tree-quick-chip {
    max-width: 90px;
    padding: 0 6px;
    font-size: 12px;
  }

  .ide-frame .tree-quick-label {
    max-width: 70px;
  }

  .ide-frame .pane-tree .fab-add {
    min-width: 48px;
    min-height: 48px;
    padding: 0 14px;
    font-size: 12px;
    bottom: 12px;
    right: 12px;
  }

  .ide-frame .pane-term .pane-header {
    flex-wrap: nowrap;
    gap: 12px;
    padding: 8px 10px;
  }

  .ide-frame .pane-term .pane-header .pane-title, .ide-frame .pane-term .pane-header .term-esc, .ide-frame .pane-term .pane-header .agent-elapsed {
    display: none;
  }

  .ide-frame .pane-term .pane-header .agent-pill {
    flex: 0 auto;
    min-width: 0;
    overflow: hidden;
  }

  .ide-frame .pane-term .pane-header .agent-pill > span:not(.agent-dot) {
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
  }

  .ide-frame .pane-term .pane-header .term-stop, .ide-frame .pane-term .pane-header .icon-btn[data-action="term-menu"] {
    flex: none;
  }
}

@media (min-width: 700px) and (max-width: 1499px) and (orientation: landscape) {
  .ide-frame .term-tools {
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
    overscroll-behavior: contain;
    flex-wrap: nowrap;
    gap: 8px;
    overflow: auto hidden;
  }

  .ide-frame .term-tools .term-tool {
    flex: none;
    justify-content: center;
    min-width: 44px;
    padding: 0 10px;
  }

  .ide-frame .term-tools .term-tool-label {
    display: none;
  }

  .ide-frame .term .term-tools .term-tool-fontgrp {
    margin-left: 8px;
  }

  .ide-frame .term .term-tools .term-tool-fontval {
    min-width: 34px;
    font-size: 11px;
  }

  .ide-frame .term-xterm .xterm {
    padding: 52px 0 56px;
  }

  .ide-frame .top-nav {
    gap: 8px;
    padding: 8px 12px;
  }

  .ide-frame .nav-brand-prefix {
    display: none;
  }

  .ide-frame .nav-brand {
    font-size: 13px;
  }

  .ide-frame .nav-pill:not(.nav-pill-active), .ide-frame .icon-btn[data-action="snippets"], .ide-frame .icon-btn[data-action="search"], .ide-frame .icon-btn[data-action="pip"] {
    display: none;
  }
}

@media (max-width: 600px) {
  .ide-frame {
    --pane-gap: 6px;
    --pane-pad: 10px;
    --radius: 14px;
    --header-h: 52px;
    grid-template-rows: auto auto auto 1fr;
  }

  .ide-frame[data-perm="bypass"] {
    grid-template-rows: auto auto auto auto 1fr;
  }

  .ide-frame .top-nav {
    gap: 8px;
    min-height: 56px;
    padding: 8px 10px;
  }

  .ide-frame .nav-burger {
    font-size: 18px;
  }

  .ide-frame .nav-brand {
    font-size: 13px;
  }

  .ide-frame .nav-brand-prefix {
    display: none;
  }

  .ide-frame .icon-btn {
    padding: 0 6px;
    font-size: 15px;
  }

  .ide-frame .nav-pill, .ide-frame .nav-avatar, .ide-frame .icon-btn[data-action="snippets"], .ide-frame .icon-btn[data-action="search"], .ide-frame .icon-btn[data-action="pip"] {
    display: none;
  }

  .ide-frame .session-ribbon {
    gap: 8px;
    padding: 6px 8px;
  }

  .ide-frame .ribbon-chip {
    gap: 6px;
    padding: 0 10px;
    font-size: 12px;
  }

  .ide-frame .ribbon-kill {
    padding: 0 8px;
  }

  .ide-frame .ribbon-add {
    padding: 0 10px;
    font-size: 12px;
  }

  .ide-frame .tab-bar {
    gap: 8px;
    padding: 6px 8px;
    display: flex;
  }

  .ide-frame .tab-btn {
    min-height: 44px;
    font-size: 13px;
  }

  .ide-frame[data-orient] .ide-grid {
    grid-template-rows: minmax(0, 1fr);
    grid-template-columns: minmax(0, 1fr);
    overflow: hidden;
  }

  .ide-frame[data-portrait-tab="tree"] .pane:not(.pane-tree), .ide-frame[data-portrait-tab="terminal"] .pane:not(.pane-term), .ide-frame[data-portrait-tab="keys"] .pane:not(.pane-prev) {
    display: none;
  }

  .ide-frame .pane {
    border-radius: 14px;
  }

  .ide-frame .pane-header {
    gap: 8px;
    min-height: 44px;
    padding: 10px 12px;
  }

  .ide-frame .pane-title {
    font-size: 12px;
  }

  .ide-frame .pane-term .pane-header {
    flex-wrap: nowrap;
    gap: 12px;
  }

  .ide-frame .pane-term .pane-header .pane-title, .ide-frame .pane-term .pane-header .term-esc, .ide-frame .pane-term .pane-header .agent-elapsed {
    display: none;
  }

  .ide-frame .pane-term .pane-header .agent-pill {
    flex: 0 auto;
    min-width: 0;
    overflow: hidden;
  }

  .ide-frame .pane-term .pane-header .term-stop, .ide-frame .pane-term .pane-header .icon-btn[data-action="term-menu"] {
    flex: none;
  }

  .ide-frame .chip-row {
    gap: 8px;
    min-height: 56px;
    padding: 8px 10px;
  }

  .ide-frame .chip {
    min-height: 44px;
    padding: 0 12px;
    font-size: 12px;
  }

  .ide-frame .mod-row {
    gap: 8px;
    min-height: 64px;
    padding: 8px;
  }

  .ide-frame .key {
    min-width: 52px;
    min-height: 48px;
    padding: 0 8px;
    font-size: 13px;
  }

  .ide-frame .key[data-wide="true"] {
    min-width: 78px;
  }

  .ide-frame .tree-quick-chip {
    max-width: 140px;
  }

  .ide-frame .tree-quick-label {
    max-width: 100px;
  }

  .ide-frame .tree-row {
    min-height: 52px;
    font-size: 13px;
  }

  .ide-frame .tree {
    padding-bottom: 80px;
  }

  .ide-frame .preview-mock {
    grid-template-columns: repeat(2, 1fr);
  }

  .ide-frame .fab-add {
    min-width: 56px;
    min-height: 56px;
    padding: 0 18px;
    font-size: 14px;
    bottom: 14px;
    right: 14px;
  }

  .ide-frame .palette-fab {
    min-width: 50px;
    min-height: 50px;
    font-size: 18px;
    bottom: 14px;
    right: 14px;
  }

  .ide-frame[data-portrait-tab="tree"] .palette-fab {
    bottom: 84px;
  }

  .ide-frame .term-tools {
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
    overscroll-behavior: contain;
    flex-wrap: nowrap;
    gap: 8px;
    overflow: auto hidden;
  }

  .ide-frame .term-tools .term-tool {
    flex: none;
    justify-content: center;
    min-width: 44px;
    padding: 0 10px;
  }

  .ide-frame .term-tools .term-tool-label {
    display: none;
  }

  .ide-frame .term .term-tools .term-tool-fontgrp {
    margin-left: 8px;
  }

  .ide-frame .term .term-tools .term-tool-fontval {
    min-width: 34px;
    font-size: 11px;
  }

  .ide-frame .term-xterm .xterm {
    padding: 52px 0 56px;
  }
}

@media (max-width: 600px) and (max-height: 480px) {
  .ide-frame .top-nav, .ide-frame .session-ribbon, .ide-frame .tab-bar, .ide-frame .palette-fab, .ide-frame .pane:not(.pane-term) .pane-header {
    display: none;
  }

  .ide-frame {
    grid-template-rows: 1fr;
  }

  .ide-frame[data-perm="bypass"] {
    grid-template-rows: auto 1fr;
  }

  .ide-frame .chip-row {
    gap: 8px;
    min-height: 48px;
    padding: 6px 10px;
  }

  .ide-frame .mod-row {
    gap: 8px;
    min-height: 56px;
    padding: 6px 8px;
  }

  .ide-frame .key {
    min-width: 44px;
    min-height: 44px;
    padding: 0 6px;
    font-size: 12px;
  }

  .ide-frame .key[data-wide="true"] {
    min-width: 64px;
  }

  .ide-frame .pane-term .pane-header {
    z-index: 8;
    background: var(--solid-2);
    border-bottom: 1px solid var(--border);
    flex-wrap: nowrap;
    gap: 12px;
    min-height: 44px;
    padding: 6px 10px;
    position: sticky;
    top: 0;
  }

  .ide-frame .pane-term .pane-header .pane-title, .ide-frame .pane-term .pane-header .term-esc, .ide-frame .pane-term .pane-header .agent-elapsed {
    display: none;
  }

  .ide-frame .pane-term .pane-header .agent-pill {
    flex: 0 auto;
    min-width: 0;
    overflow: hidden;
  }

  .ide-frame .pane-term .pane-header .agent-pill > span:not(.agent-dot) {
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
  }

  .ide-frame .pane-term .pane-header .term-stop, .ide-frame .pane-term .pane-header .icon-btn[data-action="term-menu"] {
    flex: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame {
    --ease-spring: linear;
  }

  .ide-frame *, .ide-frame :before, .ide-frame :after {
    transition: none !important;
    animation: none !important;
  }
}

.ide-frame button:focus-visible, .ide-frame a:focus-visible, .ide-frame [role="button"]:focus-visible, .ide-frame [tabindex]:focus-visible, .ide-frame input:focus-visible, .ide-frame textarea:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

.ide-frame .key, .ide-frame .chip, .ide-frame .nav-pill, .ide-frame .tab-btn, .ide-frame .ribbon-add, .ide-frame .term-onboard-cta, .ide-frame .tree-row {
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}

@keyframes aos-sheet-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }

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

@keyframes aos-sheet-out {
  from {
    opacity: 1;
    transform: translateY(0);
  }

  to {
    opacity: 0;
    transform: translateY(8px);
  }
}

@keyframes aos-backdrop-in {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.ide-frame .aos-sheet-in {
  transform-origin: bottom;
  animation: aos-sheet-in var(--t-long) var(--ease-sheet) both;
}

.ide-frame .aos-sheet-out {
  transform-origin: bottom;
  animation: aos-sheet-out var(--t-default) var(--ease-exit) both;
}

.ide-frame .aos-backdrop-in {
  animation: aos-backdrop-in var(--t-default) var(--ease-out) both;
}

@media (prefers-reduced-motion: reduce) {
  .ide-frame .aos-sheet-in, .ide-frame .aos-sheet-out, .ide-frame .aos-backdrop-in {
    animation: none !important;
  }
}

@media (prefers-contrast: more) {
  .ide-frame .top-nav, .ide-frame .pane-prev, .ide-frame .palette-fab, .ide-frame .nav-drawer, .ide-frame .ribbon-sheet, .ide-frame .term-menu {
    border: 1px solid var(--border-strong);
  }

  .ide-frame button:focus-visible, .ide-frame a:focus-visible {
    outline-width: 3px;
  }
}

@media (forced-colors: active) {
  .ide-frame .nav-pill-active, .ide-frame .tab-btn[aria-selected="true"] {
    outline: 1px solid;
  }

  .ide-frame .ribbon-dot, .ide-frame .dot {
    forced-color-adjust: none;
  }
}

@media (prefers-reduced-transparency: reduce) {
  .ide-frame .top-nav, .ide-frame .pane-prev, .ide-frame .palette-fab, .ide-frame .nav-drawer, .ide-frame .ribbon-sheet {
    background: var(--solid-3) !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }
}

.xterm {
  cursor: text;
  -webkit-user-select: none;
  user-select: none;
  position: relative;
}

.xterm.focus, .xterm:focus {
  outline: none;
}

.xterm .xterm-helpers {
  z-index: 5;
  position: absolute;
  top: 0;
}

.xterm .xterm-helper-textarea {
  opacity: 0;
  z-index: -5;
  white-space: nowrap;
  resize: none;
  border: 0;
  width: 0;
  height: 0;
  margin: 0;
  padding: 0;
  position: absolute;
  top: 0;
  left: -9999em;
  overflow: hidden;
}

.xterm .composition-view {
  color: #fff;
  white-space: nowrap;
  z-index: 1;
  background: #000;
  display: none;
  position: absolute;
}

.xterm .composition-view.active {
  display: block;
}

.xterm .xterm-viewport {
  cursor: default;
  background-color: #000;
  position: absolute;
  inset: 0;
  overflow-y: scroll;
}

.xterm .xterm-screen {
  position: relative;
}

.xterm .xterm-screen canvas {
  position: absolute;
  top: 0;
  left: 0;
}

.xterm .xterm-scroll-area {
  visibility: hidden;
}

.xterm-char-measure-element {
  visibility: hidden;
  line-height: normal;
  display: inline-block;
  position: absolute;
  top: 0;
  left: -9999em;
}

.xterm.enable-mouse-events {
  cursor: default;
}

.xterm.xterm-cursor-pointer, .xterm .xterm-cursor-pointer {
  cursor: pointer;
}

.xterm.column-select.focus {
  cursor: crosshair;
}

.xterm .xterm-accessibility:not(.debug), .xterm .xterm-message {
  z-index: 10;
  color: #0000;
  pointer-events: none;
  position: absolute;
  inset: 0;
}

.xterm .xterm-accessibility-tree:not(.debug) ::selection {
  color: #0000;
}

.xterm .xterm-accessibility-tree {
  -webkit-user-select: text;
  user-select: text;
  white-space: pre;
}

.xterm .live-region {
  width: 1px;
  height: 1px;
  position: absolute;
  left: -9999px;
  overflow: hidden;
}

.xterm-dim {
  opacity: 1 !important;
}

.xterm-underline-1 {
  text-decoration: underline;
}

.xterm-underline-2 {
  -webkit-text-decoration: underline double;
  text-decoration: underline double;
}

.xterm-underline-3 {
  -webkit-text-decoration: underline wavy;
  text-decoration: underline wavy;
}

.xterm-underline-4 {
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
}

.xterm-underline-5 {
  -webkit-text-decoration: underline dashed;
  text-decoration: underline dashed;
}

.xterm-overline {
  text-decoration: overline;
}

.xterm-overline.xterm-underline-1 {
  text-decoration: underline overline;
}

.xterm-overline.xterm-underline-2 {
  -webkit-text-decoration: overline double underline;
  text-decoration: overline double underline;
}

.xterm-overline.xterm-underline-3 {
  -webkit-text-decoration: overline wavy underline;
  text-decoration: overline wavy underline;
}

.xterm-overline.xterm-underline-4 {
  -webkit-text-decoration: overline dotted underline;
  text-decoration: overline dotted underline;
}

.xterm-overline.xterm-underline-5 {
  -webkit-text-decoration: overline dashed underline;
  text-decoration: overline dashed underline;
}

.xterm-strikethrough {
  text-decoration: line-through;
}

.xterm-screen .xterm-decoration-container .xterm-decoration {
  z-index: 6;
  position: absolute;
}

.xterm-screen .xterm-decoration-container .xterm-decoration.xterm-decoration-top-layer {
  z-index: 7;
}

.xterm-decoration-overview-ruler {
  z-index: 8;
  pointer-events: none;
  position: absolute;
  top: 0;
  right: 0;
}

.xterm-decoration-top {
  z-index: 2;
  position: relative;
}

