@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Space+Grotesk:wght@300;400;500;600;700&family=Orbitron:wght@400;500;600;700&family=Oxanium:wght@300;400;500;600;700&family=Rajdhani:wght@300;400;500;600;700&family=Chakra+Petch:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400;1,600&family=Share+Tech+Mono&family=Michroma&family=Audiowide&family=Quantico:ital,wght@0,400;0,700;1,400;1,700&family=IBM+Plex+Mono:wght@300;400;500;600;700&display=swap";
@import "https://fonts.googleapis.com/css2?family=Oswald:wght@400;700&family=Lusitana:wght@400;700&family=Barlow:wght@400;700&family=Turret+Road:wght@400;700&family=Roboto+Slab:wght@400;700&family=Saira:wght@400;700&family=Sarpanch:wght@400;700&family=Silkscreen:wght@400;700&family=Gloock&display=swap";


/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */
@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-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-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-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
    }
  }
}
@layer theme {
  :root, :host {
    --font-sans: "Space Grotesk", ui-sans-serif, system-ui, sans-serif;
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --color-emerald-500: oklch(69.6% .17 162.48);
    --color-blue-500: oklch(62.3% .214 259.815);
    --color-zinc-900: oklch(21% .006 285.885);
    --color-zinc-950: oklch(14.1% .005 285.823);
    --color-black: #000;
    --color-white: #fff;
    --spacing: .25rem;
    --container-md: 28rem;
    --container-xl: 36rem;
    --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-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --text-7xl: 4.5rem;
    --text-7xl--line-height: 1;
    --text-8xl: 6rem;
    --text-8xl--line-height: 1;
    --text-9xl: 8rem;
    --text-9xl--line-height: 1;
    --font-weight-light: 300;
    --font-weight-medium: 500;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;
    --font-weight-black: 900;
    --tracking-tighter: -.05em;
    --tracking-widest: .1em;
    --leading-tight: 1.25;
    --leading-relaxed: 1.625;
    --radius-sm: .25rem;
    --radius-xl: .75rem;
    --radius-2xl: 1rem;
    --radius-3xl: 1.5rem;
    --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;
    --blur-md: 12px;
    --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);
    --font-display: "Syne", sans-serif;
    --color-accent: #cf0;
  }
}
@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;
    -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;
  }
}
@layer components;
@layer utilities {
  .pointer-events-none {
    pointer-events: none;
  }

  .visible {
    visibility: visible;
  }

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .relative {
    position: relative;
  }

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

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

  .start {
    inset-inline-start: var(--spacing);
  }

  .end {
    inset-inline-end: var(--spacing);
  }

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

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

  .top-1\/4 {
    top: 25%;
  }

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

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

  .right-1\/4 {
    right: 25%;
  }

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

  .bottom-1\/4 {
    bottom: 25%;
  }

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

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

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

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

  .left-1\/4 {
    left: 25%;
  }

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

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

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

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

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

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

  .z-\[5\] {
    z-index: 5;
  }

  .z-\[100\] {
    z-index: 100;
  }

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

  .mx-auto {
    margin-inline: auto;
  }

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

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

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

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

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

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

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

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

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

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

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

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

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

  .aspect-\[16\/10\] {
    aspect-ratio: 16 / 10;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

  .h-auto {
    height: auto;
  }

  .h-full {
    height: 100%;
  }

  .h-px {
    height: 1px;
  }

  .h-screen {
    height: 100vh;
  }

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

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

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

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

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

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

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

  .w-\[60vw\] {
    width: 60vw;
  }

  .w-\[80vw\] {
    width: 80vw;
  }

  .w-\[160vw\] {
    width: 160vw;
  }

  .w-full {
    width: 100%;
  }

  .w-px {
    width: 1px;
  }

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

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

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

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

  .flex-none {
    flex: none;
  }

  .origin-left {
    transform-origin: 0;
  }

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

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

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

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

  .cursor-default {
    cursor: default;
  }

  .resize {
    resize: both;
  }

  .grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

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

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

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

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

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

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

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

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

  :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)));
  }

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

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

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

  .overflow-hidden {
    overflow: hidden;
  }

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

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

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

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

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

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

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

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

  .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\/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-\[\#050505\] {
    background-color: #050505;
  }

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

  .bg-accent\/10 {
    background-color: #ccff001a;
  }

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

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

  .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\/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-blue-500\/10 {
    background-color: #3080ff1a;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-blue-500\/10 {
      background-color: color-mix(in oklab, var(--color-blue-500) 10%, 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-transparent {
    background-color: #0000;
  }

  .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-zinc-900 {
    background-color: var(--color-zinc-900);
  }

  .bg-zinc-950\/40 {
    background-color: #09090b66;
  }

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

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

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

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

  .from-\[\#050505\] {
    --tw-gradient-from: #050505;
    --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));
  }

  .from-black {
    --tw-gradient-from: var(--color-black);
    --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));
  }

  .from-black\/20 {
    --tw-gradient-from: #0003;
  }

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

  .from-black\/20 {
    --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));
  }

  .from-white {
    --tw-gradient-from: var(--color-white);
    --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-\[\#050505\]\/40 {
    --tw-gradient-via: oklab(11.4918% 7.45058e-9 7.45058e-9 / .4);
    --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);
  }

  .via-black\/90 {
    --tw-gradient-via: #000000e6;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .via-black\/90 {
      --tw-gradient-via: color-mix(in oklab, var(--color-black) 90%, transparent);
    }
  }

  .via-black\/90 {
    --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);
  }

  .via-transparent {
    --tw-gradient-via: transparent;
    --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-black\/60 {
    --tw-gradient-to: #0009;
  }

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

  .to-black\/60 {
    --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));
  }

  .to-transparent {
    --tw-gradient-to: transparent;
    --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));
  }

  .bg-repeat {
    background-repeat: repeat;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--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-6xl {
    font-size: var(--text-6xl);
    line-height: var(--tw-leading, var(--text-6xl--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-\[8px\] {
    font-size: 8px;
  }

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

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

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

  .text-\[12vw\] {
    font-size: 12vw;
  }

  .text-\[15vw\] {
    font-size: 15vw;
  }

  .leading-\[0\.8\] {
    --tw-leading: .8;
    line-height: .8;
  }

  .leading-\[0\.9\] {
    --tw-leading: .9;
    line-height: .9;
  }

  .leading-\[0\.85\] {
    --tw-leading: .85;
    line-height: .85;
  }

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

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

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

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

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

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

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

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

  .tracking-\[0\.3em\] {
    --tw-tracking: .3em;
    letter-spacing: .3em;
  }

  .tracking-\[0\.4em\] {
    --tw-tracking: .4em;
    letter-spacing: .4em;
  }

  .tracking-\[0\.22em\] {
    --tw-tracking: .22em;
    letter-spacing: .22em;
  }

  .tracking-\[0\.26em\] {
    --tw-tracking: .26em;
    letter-spacing: .26em;
  }

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

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

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

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

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

  .text-black\/90 {
    color: #000000e6;
  }

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

  .text-transparent {
    color: #0000;
  }

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

  .text-white\/50 {
    color: #ffffff80;
  }

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

  .text-white\/60 {
    color: #fff9;
  }

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

  .text-white\/70 {
    color: #ffffffb3;
  }

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

  .text-white\/80 {
    color: #fffc;
  }

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

  .uppercase {
    text-transform: uppercase;
  }

  .italic {
    font-style: italic;
  }

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

  .opacity-0 {
    opacity: 0;
  }

  .opacity-30 {
    opacity: .3;
  }

  .opacity-40 {
    opacity: .4;
  }

  .opacity-45 {
    opacity: .45;
  }

  .opacity-55 {
    opacity: .55;
  }

  .opacity-60 {
    opacity: .6;
  }

  .opacity-70 {
    opacity: .7;
  }

  .opacity-80 {
    opacity: .8;
  }

  .opacity-\[0\.03\] {
    opacity: .03;
  }

  .opacity-\[0\.08\] {
    opacity: .08;
  }

  .opacity-\[0\.10\] {
    opacity: .1;
  }

  .mix-blend-difference {
    mix-blend-mode: difference;
  }

  .mix-blend-multiply {
    mix-blend-mode: multiply;
  }

  .blur-\[120px\] {
    --tw-blur: blur(120px);
    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,  );
  }

  .brightness-0 {
    --tw-brightness: brightness(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,  );
  }

  .grayscale {
    --tw-grayscale: grayscale(100%);
    filter: var(--tw-blur,  ) var(--tw-brightness,  ) var(--tw-contrast,  ) var(--tw-grayscale,  ) var(--tw-hue-rotate,  ) var(--tw-invert,  ) var(--tw-saturate,  ) var(--tw-sepia,  ) var(--tw-drop-shadow,  );
  }

  .invert {
    --tw-invert: invert(100%);
    filter: var(--tw-blur,  ) var(--tw-brightness,  ) var(--tw-contrast,  ) var(--tw-grayscale,  ) var(--tw-hue-rotate,  ) var(--tw-invert,  ) var(--tw-saturate,  ) var(--tw-sepia,  ) var(--tw-drop-shadow,  );
  }

  .filter {
    filter: var(--tw-blur,  ) var(--tw-brightness,  ) var(--tw-contrast,  ) var(--tw-grayscale,  ) var(--tw-hue-rotate,  ) var(--tw-invert,  ) var(--tw-saturate,  ) var(--tw-sepia,  ) var(--tw-drop-shadow,  );
  }

  .backdrop-blur-md {
    --tw-backdrop-blur: blur(var(--blur-md));
    -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-all {
    transition-property: all;
    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-opacity {
    transition-property: opacity;
    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));
  }

  .delay-700 {
    transition-delay: .7s;
  }

  .duration-300 {
    --tw-duration: .3s;
    transition-duration: .3s;
  }

  .duration-500 {
    --tw-duration: .5s;
    transition-duration: .5s;
  }

  .duration-700 {
    --tw-duration: .7s;
    transition-duration: .7s;
  }

  .will-change-transform {
    will-change: transform;
  }

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

  @media (hover: hover) {
    .group-hover\:scale-110:is(:where(.group):hover *) {
      --tw-scale-x: 110%;
      --tw-scale-y: 110%;
      --tw-scale-z: 110%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }

    .group-hover\:text-accent:is(:where(.group):hover *) {
      color: var(--color-accent);
    }

    .group-hover\:opacity-20:is(:where(.group):hover *) {
      opacity: .2;
    }

    .group-hover\:opacity-100:is(:where(.group):hover *) {
      opacity: 1;
    }

    .group-hover\:grayscale-0:is(:where(.group):hover *) {
      --tw-grayscale: grayscale(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,  );
    }

    .hover\:border-accent\/30:hover {
      border-color: #ccff004d;
    }

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

    .hover\:border-accent\/50:hover {
      border-color: #ccff0080;
    }

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

    .hover\:bg-white:hover {
      background-color: var(--color-white);
    }

    .hover\:text-accent:hover {
      color: var(--color-accent);
    }

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

    .hover\:opacity-100:hover {
      opacity: 1;
    }

    .hover\:grayscale-0:hover {
      --tw-grayscale: grayscale(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,  );
    }
  }

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

    .sm\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:left-24 {
      left: calc(var(--spacing) * 24);
    }

    .md\:flex {
      display: flex;
    }

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

    .md\:h-\[1200px\] {
      height: 1200px;
    }

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

    .md\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .md\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .md\:grid-cols-5 {
      grid-template-columns: repeat(5, minmax(0, 1fr));
    }

    .md\:flex-row {
      flex-direction: row;
    }

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

    .md\:px-24 {
      padding-inline: calc(var(--spacing) * 24);
    }

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

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

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

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

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

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

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

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

    .md\:text-\[8vw\] {
      font-size: 8vw;
    }

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

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

    .lg\:h-\[1600px\] {
      height: 1600px;
    }

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

    .lg\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .lg\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .lg\:gap-20 {
      gap: calc(var(--spacing) * 20);
    }
  }

  .text-balance {
    text-wrap: balance;
  }
}
:root {
  --bg: #050505;
  --fg: #fff;
  --accent: #cf0;
}
body {
  color: #fff;
  -webkit-font-smoothing: antialiased;
  background-color: #050505;
  font-family: Space Grotesk, sans-serif;
  font-size: 14px;
  font-weight: 300;
  overflow-x: hidden;
}
main {
  isolation: isolate;
}
.text-accent {
  color: var(--accent);
}
.bg-accent {
  background-color: var(--accent);
}
.border-accent {
  border-color: var(--accent);
}
.font-display {
  font-family: var(--font-display);
}
::selection {
  background: var(--accent);
  color: #000;
}
html.lenis {
  height: auto;
}
.lenis-smooth {
  scroll-behavior: auto !important;
}
.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}
.lenis-stopped {
  overflow: hidden;
}
.bg-noise {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
}
.border-text {
  -webkit-text-stroke: 1px #ffffff4d;
  color: #0000;
}
@keyframes accent-stripes {
  from {
    background-position: 0 0;
  }

  to {
    background-position: 120% 120%;
  }
}
.accent-bar-stripes {
  background-image: repeating-linear-gradient(135deg, #00000047 0 10px, #0000000f 10px 20px);
  background-size: 220% 220%;
  animation: 45s linear infinite accent-stripes;
}
@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-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-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-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@keyframes pulse {
  50% {
    opacity: .5;
  }
}


/* --- Custom patches (cpanel) --- */

.hero-wall-bg{
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: #000;
  background-blend-mode: normal;
  /* Textura sutil pero visible bajo el efecto */
  opacity: 0.38;
  filter: brightness(0.55) contrast(1.18) saturate(0.75);
  transform: scale(1.02);
}
.hero-wall-overlay{
  /* Oscurece sin matar la textura */
  background: radial-gradient(70% 60% at 50% 40%,
    rgba(0,0,0,0.18) 0%,
    rgba(0,0,0,0.55) 75%,
    rgba(0,0,0,0.78) 100%);
}

.hero-vignette{
  background: radial-gradient(ellipse at center,
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0.35) 55%,
    rgba(0,0,0,0.75) 100%);
}
@media (hover:none){
  .hero-wall-bg{ opacity: 0.42; filter: brightness(0.60) contrast(1.12) saturate(0.78); }
}

.ramon-slot{
  display:inline-block;
  position:relative;
  /* Reserva espacio para el font-swap sin “bailes” y sin recortes */
  width: calc(var(--ramon-w, 6.5ch) + 24px);
  height: calc(var(--ramon-h, 1em) + 2px);
  line-height: 0.7;
  overflow: visible; /* evita recortes en algunas fuentes */
  vertical-align: bottom;
  margin-bottom: -0.22em; /* acerca RAMÓN a TENDERO */
}
.ramon-layer{
  position:absolute;
  left:0;
  bottom:0;
  white-space: nowrap;
  width: 100%;
}

/* --- RAMÓN font swap: fade rápido (orgánico) --- */
.ramon-prev{ opacity: 0; }
.ramon-next{ opacity: 1; }

/* durante el swap cruzamos capas sin artificios */
.ramon-slot.ramon-morphing .ramon-layer{
  will-change: opacity, filter, transform;
}

.ramon-slot.ramon-morphing .ramon-prev{
  opacity: 1;
  animation: ramonFadeOut var(--ramon-fade-ms, 140ms) ease-out both;
}

.ramon-slot.ramon-morphing .ramon-next{
  opacity: 0;
  animation: ramonFadeIn var(--ramon-fade-ms, 140ms) ease-out both;
}

@keyframes ramonFadeIn{
  from{
    opacity: 0;
    filter: blur(6px);
    transform: translate3d(0, -1px, 0);
  }
  to{
    opacity: 1;
    filter: blur(0px);
    transform: translate3d(0, 0, 0);
  }
}

@keyframes ramonFadeOut{
  from{
    opacity: 1;
    filter: blur(0px);
    transform: translate3d(0, 0, 0);
  }
  to{
    opacity: 0;
    filter: blur(6px);
    transform: translate3d(0, 1px, 0);
  }
}


/* --- Portfolio gallery (PRO controls) --- */
.portfolio-gallery{
  position:absolute;
  inset:0;
  /* Allow vertical page scroll, but keep horizontal gestures for the slider */
  touch-action: pan-y pinch-zoom;
  will-change: transform;
}
@media (hover:none){
  .portfolio-gallery{ cursor: grab; }
  .portfolio-gallery:active{ cursor: grabbing; }
}

/* Mobile hint for swipe (hidden after first drag via data-hint="0") */
@media (hover:none){
  .portfolio-gallery[data-hint="1"]::after{
    content: "Desliza ↔";
    position:absolute;
    left: 50%;
    bottom: 48px;
    transform: translateX(-50%);
    z-index: 7;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(0,0,0,.55);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    font-size: 10px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(204,255,0,.95);
    pointer-events: none;
    opacity: .95;
  }
}

@media (hover:hover){
  .portfolio-gallery{ cursor: pointer; }
}

.portfolio-frames{
  position:absolute;
  inset:0;
  display:flex;
  width:100%;
  height:100%;
  /* idx handles the current slide, dragX adds Apple-like finger tracking */
  transform: translate3d(calc(var(--idx, 0) * -100% + var(--dragX, 0px)), 0, 0);
  transition: transform .42s cubic-bezier(.16,1,.3,1);
  will-change: transform;
}
.portfolio-gallery[data-dragging="1"] .portfolio-frames{
  transition: none;
}


.portfolio-frame-img{
  flex: 0 0 100%;
  display:block;
  width:100%;
  height:100%;
  /* Ajuste sin "márgenes" (rellena el contenedor) */
  object-fit: cover;
  object-position: center;
  border-radius: inherit;
  filter: grayscale(1);
  /* Sin zoom para evitar recortes extra */
  transform: none;
  transition: filter .45s ease, transform .8s cubic-bezier(.16,1,.3,1);
}
.group:hover .portfolio-frame-img{
  filter: grayscale(0);
  transform: none;
}
@media (hover:none){
  .portfolio-frame-img{ filter: grayscale(1); transform: none; }
}

/* Proyecto con una sola imagen: rellena el contenedor sin barras */
.portfolio-single{
  object-fit: cover !important;
  object-position: center;
  display: block;
}

/* Controls */
/* Autoplay + dots: ocultamos flechas (más limpio) */
.gallery-nav{ display:none !important; }

.gallery-nav{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 6;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: rgba(255,255,255,.92);
  font-size: 22px;
  line-height: 1;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease, border-color .25s ease, color .25s ease;
}
.gallery-prev{ left: 12px; }
.gallery-next{ right: 12px; }

.group:hover .gallery-nav{
  opacity: 1;
  pointer-events: auto;
}
.gallery-nav:hover{
  border-color: rgba(204,255,0,.55);
  color: rgba(204,255,0,.95);
}

.gallery-dots{
  position:absolute;
  left: 50%;
  bottom: 48px;
  transform: translateX(-50%) translateY(6px);
  z-index: 6;
  display:flex;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.45);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
}
.group:hover .gallery-dots{
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.gallery-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.25);
  border: 1px solid rgba(255,255,255,.12);
}
.gallery-dot[data-active="1"]{
  background: rgba(204,255,0,.95);
  border-color: rgba(204,255,0,.55);
  box-shadow: 0 0 0 6px rgba(204,255,0,.10);
}

.gallery-badge{
  position:absolute;
  top: 12px;
  right: 12px;
  z-index: 6;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(204,255,0,.95);
}

/* Mobile: controls visible, compact */
@media (hover:none){
  .gallery-nav{ opacity: 1; pointer-events: auto; width: 36px; height: 36px; }
  .gallery-dots{ opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }
}

/* --- Brand logos: blanco por defecto, color al hover --- */
.brand-logo{
  filter: brightness(0) invert(1);
  opacity: .92;
}
.group:hover .brand-logo{
  filter: none;
  opacity: 1;
}

@media (hover: none){
  .gallery-badge{ cursor: pointer; }
}


/* --- IA card: más alta y con padding consistente --- */
.ai-card{
  padding: 28px !important;
  min-height: 148px;
}
.ai-card > div:last-child{
  padding-right: 6px;
}
@media (max-width: 768px){
  .ai-card{ padding: 22px !important; min-height: 160px; }
}

/* --- Retrato: separador inferior verde muy fino (pro) --- */
.portrait-section{ position: relative; }
.portrait-section::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:1px;
  background: linear-gradient(90deg, transparent 0%, rgba(204,255,0,0.35) 18%, rgba(204,255,0,0.95) 50%, rgba(204,255,0,0.35) 82%, transparent 100%);
  background-size: 200% 100%;
  opacity: .9;
  pointer-events:none;
  filter: drop-shadow(0 0 10px rgba(204,255,0,.15));
  animation: portraitLineShimmer 6.5s linear infinite;
}
@keyframes portraitLineShimmer{
  0%{ background-position: 0% 0%; }
  100%{ background-position: 200% 0%; }
}




/* === Marcas desarrolladas: zoom PRO al hover ========================= */
.brand-logo{
  will-change: transform, filter, opacity;
  transform: translateZ(0);
  transform-origin: 50% 50%;
}
@media (hover:hover){
  .group:hover .brand-logo{
    transform: scale(1.50);
    filter: none drop-shadow(0 18px 40px rgba(0,0,0,0.55)) drop-shadow(0 0 24px rgba(182,255,0,0.18));
    opacity: 1;
  }
}

/* === Web cards: scrollbar “navegador” (progreso del scroll) =========== */
.web-preview{
  position: relative;
}
.web-scrollbar{
  --thumb-h: 28%;
  position:absolute;
  top: 10px;
  right: 10px;
  bottom: 10px;
  width: 9px;
  border-radius: 999px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.14);
  backdrop-filter: blur(10px);
  opacity: 0.65;
  transition: opacity .35s ease, transform .35s ease;
  pointer-events:none;
  transform: translateZ(0);
}
.group:hover .web-scrollbar{
  opacity: 0.95;
}
.web-scrollbar-thumb{
  position:absolute;
  left: 1px;
  right: 1px;
  top: 0;
  height: var(--thumb-h);
  border-radius: 999px;
  background: rgba(255,255,255,0.70);
  box-shadow: 0 0 0 1px rgba(0,0,0,0.18) inset, 0 10px 25px rgba(0,0,0,0.35);
}
.group:hover .web-scrollbar-thumb{
  animation: webThumbMove 8s linear infinite alternate;
}
@keyframes webThumbMove{
  from{ top: 0; }
  to{ top: calc(100% - var(--thumb-h)); }
}
@media (hover:none){
  .web-scrollbar{ opacity: 0.9; }
  .web-scrollbar-thumb{ animation: none; }
}

/* Touch: tap to "scroll" the long screenshot (JS toggles .is-scroll for one cycle) */
@media (hover:none){
  .web-preview{ touch-action: manipulation; }
  .web-preview[data-hint="1"]::after{
    content: "Toca para scroll";
    position:absolute;
    left: 50%;
    bottom: 12px;
    transform: translateX(-50%);
    z-index: 7;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(0,0,0,.55);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    font-size: 10px;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(204,255,0,.95);
    pointer-events:none;
    opacity: .92;
  }
  .web-preview.is-scroll::after, .web-preview.is-active::after{ opacity: 0; }

  .web-preview.is-active img{
    filter: grayscale(0) !important;
  }
  .web-preview.is-scroll img{
    filter: grayscale(0) !important;
    will-change: transform;
    animation: webPreviewScroll 8s linear infinite alternate;
  }
  .web-preview.is-scroll .web-scrollbar-thumb{
    animation: webThumbMove 8s linear infinite alternate;
  }
}

@keyframes webPreviewScroll{
  from{ transform: translate3d(0, 0%, 0); }
  to{ transform: translate3d(0, -60%, 0); }
}

/* === Quote: font swap para "cómo resuelves" =========================== */
.solve-slot{
  display:inline-block;
  position:relative;
  width: calc(var(--solve-w, 12ch) + 10px);
  height: calc(var(--solve-h, 1em) + 2px);
  overflow: visible;
  vertical-align: baseline;
}
.solve-layer{
  position:absolute;
  left:0;
  bottom:0;
  white-space: nowrap;
  width:100%;
}
.solve-prev{ opacity: 0; }
.solve-next{ opacity: 1; }

.solve-slot.solve-morphing .solve-layer{
  will-change: opacity, filter, transform;
}
.solve-slot.solve-morphing .solve-prev{
  opacity: 1;
  animation: solveFadeOut var(--solve-fade-ms, 140ms) ease-out both;
}
.solve-slot.solve-morphing .solve-next{
  opacity: 0;
  animation: solveFadeIn var(--solve-fade-ms, 140ms) ease-out both;
}
@keyframes solveFadeIn{
  from{ opacity: 0; filter: blur(6px); transform: translate3d(0, -1px, 0); }
  to{ opacity: 1; filter: blur(0); transform: translate3d(0, 0, 0); }
}
@keyframes solveFadeOut{
  from{ opacity: 1; filter: blur(0); transform: translate3d(0, 0, 0); }
  to{ opacity: 0; filter: blur(6px); transform: translate3d(0, 1px, 0); }
}


/* === Quote strokes: líneas finas con brillo sutil ========================= */
.quote-strokes{
  position: relative;
  overflow: hidden;
}
.quote-strokes::before,
.quote-strokes::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(90deg,
    rgba(207,255,0,0) 0%,
    rgba(207,255,0,0.95) 35%,
    rgba(207,255,0,0.95) 65%,
    rgba(207,255,0,0) 100%
  );
  opacity: 0.75;
  filter: drop-shadow(0 0 10px rgba(207,255,0,0.20));
  background-size: 200% 100%;
  animation: quoteStrokeScan 6.5s linear infinite;
}
.quote-strokes::before{ top: 0; }
.quote-strokes::after{
  bottom: 0;
  opacity: 0.55;
  animation-duration: 8.5s;
  animation-direction: reverse;
}

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


/* =======================================================================
   LANGUAGE SWITCH (ES/EN) — top nav
   - Integrated “badge / pill” so it matches the site style.
   - Uses mix-blend-mode: normal to avoid the nav's mix-blend-difference.
   ======================================================================= */
.lang-switch{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 6px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 18px 45px rgba(0,0,0,.32);
  margin-left: 28px; /* spacing from "Contacto" */
  mix-blend-mode: normal;
}

.lang-switch__btn{
  width: 28px;
  height: 20px;
  border-radius: 999px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 1px solid rgba(255,255,255,.16);
  transform: translateZ(0);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, filter .18s ease;
}

.lang-switch__btn img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display:block;
  transform: scale(1.04);
}

.lang-switch__btn:hover{
  transform: translateY(-1px) scale(1.04);
  border-color: rgba(204,255,0,.55);
  box-shadow: 0 20px 55px rgba(0,0,0,.38);
  filter: saturate(1.05);
}

@media (max-width: 768px){
  .lang-switch{ margin-left: 18px; padding: 5px 6px; gap: 8px; }
  .lang-switch__btn{ width: 24px; height: 18px; }
}

/* =======================================================================
   PORTFOLIO VIDEO — hover play (lazy)
   - No preload (handled by JS), fade cover out and video in.
   ======================================================================= */
.portfolio-video{
  position:absolute;
  inset:0;
  border-radius: inherit;
  touch-action: manipulation;
}
@media (hover:none){
  .portfolio-video{ cursor: pointer; }
}

.portfolio-video-cover{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit: cover;
  border-radius: inherit;
  filter: grayscale(1);
  transform: scale(1.03);
  opacity: 1;
  transition: filter .45s ease, transform .8s cubic-bezier(.16,1,.3,1), opacity .28s ease;
  will-change: opacity, transform;
}
.group:hover .portfolio-video-cover{
  filter: grayscale(0);
  transform: scale(1.05);
}
.portfolio-video-el{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit: cover;
  border-radius: inherit;
  opacity: 0;
  transform: scale(1.03);
  transition: opacity .22s ease, transform .6s cubic-bezier(.16,1,.3,1);
  will-change: opacity, transform;
}
.portfolio-video.is-playing .portfolio-video-el{
  opacity: 1;
  transform: scale(1.05);
}
.portfolio-video.is-playing .portfolio-video-cover{
  opacity: 0;
}
.video-badge{
  /* inherits .gallery-badge style — this is only a hook if you want tweaks later */
}


/* =======================================================================
   FLOATING WHATSAPP (FAKE) — opens an email CTA
   ======================================================================= */
.rt-wa{
  position: fixed;
  right: 50px;
  bottom: 50px;
  z-index: 9999;
  display:flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 14px;
  mix-blend-mode: normal;
}
.rt-wa *{ box-sizing: border-box; }

.rt-wa-panel{
  width: 360px;
  max-width: calc(100vw - 40px);
  border-radius: 22px;
  overflow:hidden;
  background: rgba(14,14,14,.92);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 45px 120px rgba(0,0,0,.60);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  opacity: 0;
  transform: translateY(10px) scale(.98);
  pointer-events: none;
  transition: opacity .22s ease, transform .22s cubic-bezier(.16,1,.3,1);
}

.rt-wa[data-open="1"] .rt-wa-panel{
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}

.rt-wa-head{
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 14px 14px 12px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}

.rt-wa-avatar{
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(204,255,0,.55);
  color: rgba(255,255,255,.92);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.rt-wa-head-text{ flex: 1; min-width: 0; }
.rt-wa-title{
  font-weight: 800;
  letter-spacing: .08em;
  font-size: 13px;
  line-height: 1.1;
  color: rgba(255,255,255,.95);
}
.rt-wa-sub{
  margin-top: 2px;
  font-size: 12px;
  color: rgba(255,255,255,.55);
  font-weight: 500;
}

.rt-wa-close{
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.85);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.rt-wa-close:hover{
  transform: scale(1.05);
  background: rgba(255,255,255,.10);
  border-color: rgba(204,255,0,.35);
}

.rt-wa-body{
  padding: 14px;
  display:flex;
  flex-direction: column;
  gap: 12px;
}

.rt-wa-bubble{
  border-radius: 18px;
  background: rgba(204,255,0,.10);
  border: 1px solid rgba(204,255,0,.22);
  padding: 14px;
  color: rgba(255,255,255,.78);
  font-size: 14px;
  line-height: 1.35;
}
.rt-wa-spacer{ height: 10px; }
.rt-wa-email-inline{
  margin-top: 2px;
  color: rgba(204,255,0,.95);
  font-weight: 800;
  letter-spacing: .02em;
}

.rt-wa-email-btn{
  width: 100%;
  border-radius: 16px;
  background: var(--color-accent);
  color: rgba(0,0,0,.90);
  font-weight: 900;
  text-align: center;
  padding: 14px 16px;
  letter-spacing: .02em;
  box-shadow: 0 18px 45px rgba(0,0,0,.35);
  transition: transform .18s ease, filter .18s ease;
}
.rt-wa-email-btn:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
}

.rt-wa-fab{
  width: 64px;
  height: 64px;
  border-radius: 999px;
  background: var(--color-accent);
  border: 1px solid rgba(0,0,0,.28);
  box-shadow: 0 25px 70px rgba(0,0,0,.45);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor: pointer;
  transition: transform .18s ease, filter .18s ease;
  padding: 0;
}
.rt-wa-fab:hover{
  transform: translateY(-2px) scale(1.02);
  filter: brightness(1.02);
}
.rt-wa-fab img{
  width: 76%;
  height: 76%;
  object-fit: contain;
  display:block;
  /* subtle depth */
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.22));
}

  .rt-wa-panel{ width: 340px; }
}


/* =======================================================================
   TOUCH: tap to reveal color (JS adds .is-active on .project-card)
   ======================================================================= */
.project-card.is-active .portfolio-frame-img,
.project-card.is-active .portfolio-single,
.project-card.is-active .portfolio-video-cover{
  filter: grayscale(0) !important;
}

/* Touch ergonomics for gallery controls */
@media (hover:none){
  .gallery-dots{
    padding: 10px 12px;
    gap: 10px;
  }
  .gallery-dot{
    width: 12px;
    height: 12px;
  }
  .gallery-dot[data-active="1"]{
    box-shadow: 0 0 0 8px rgba(204,255,0,.10);
  }
}

/* =======================================================================
   CURSOR EFFECT — only visible inside the quote section
   ======================================================================= */
#rt-cursor-canvas{
  position: fixed;
  inset: 0;
  z-index: 120;
  pointer-events: none;
  opacity: 0;
  transition: opacity .18s ease;
}
body.rt-cursor-active #rt-cursor-canvas{ opacity: 1; }

@media (hover:hover) and (pointer:fine){
  body.rt-cursor-active .quote-strokes{ cursor: none; }
}

@media (prefers-reduced-motion: reduce){
  #rt-cursor-canvas{ display:none !important; }
  .quote-strokes{ cursor: auto !important; }
}
