    *,
    :before,
    :after {
      --tw-border-spacing-x: 0;
      --tw-border-spacing-y: 0;
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-rotate: 0;
      --tw-skew-x: 0;
      --tw-skew-y: 0;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-pan-x: ;
      --tw-pan-y: ;
      --tw-pinch-zoom: ;
      --tw-scroll-snap-strictness: proximity;
      --tw-gradient-from-position: ;
      --tw-gradient-via-position: ;
      --tw-gradient-to-position: ;
      --tw-ordinal: ;
      --tw-slashed-zero: ;
      --tw-numeric-figure: ;
      --tw-numeric-spacing: ;
      --tw-numeric-fraction: ;
      --tw-ring-inset: ;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-color: rgb(59 130 246/.5);
      --tw-ring-offset-shadow: 0 0#0000;
      --tw-ring-shadow: 0 0#0000;
      --tw-shadow: 0 0#0000;
      --tw-shadow-colored: 0 0#0000;
      --tw-blur: ;
      --tw-brightness: ;
      --tw-contrast: ;
      --tw-grayscale: ;
      --tw-hue-rotate: ;
      --tw-invert: ;
      --tw-saturate: ;
      --tw-sepia: ;
      --tw-drop-shadow: ;
      --tw-backdrop-blur: ;
      --tw-backdrop-brightness: ;
      --tw-backdrop-contrast: ;
      --tw-backdrop-grayscale: ;
      --tw-backdrop-hue-rotate: ;
      --tw-backdrop-invert: ;
      --tw-backdrop-opacity: ;
      --tw-backdrop-saturate: ;
      --tw-backdrop-sepia: ;
      --tw-contain-size: ;
      --tw-contain-layout: ;
      --tw-contain-paint: ;
      --tw-contain-style:
    }

    *,
    :before,
    :after {
      box-sizing: border-box;
      border-width: 0;
      border-style: solid;
      border-color: #e5e7eb
    }

    :before,
    :after {
      --tw-content: ""
    }

    html,
    :host {
      line-height: 1.5;
      -webkit-text-size-adjust: 100%;
      -moz-tab-size: 4;
      -o-tab-size: 4;
      tab-size: 4;
      font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji";
      font-feature-settings: normal;
      font-variation-settings: normal;
      -webkit-tap-highlight-color: transparent
    }

    body {
      margin: 0;
      line-height: inherit
    }

    a {
      text-decoration: inherit
    }

    button {
      font-family: inherit;
      font-feature-settings: inherit;
      font-variation-settings: inherit;
      font-weight: inherit;
      line-height: inherit;
      letter-spacing: inherit;
      margin: 0;
      padding: 0
    }

    button {
      text-transform: none
    }

    button {
      -webkit-appearance: button;
      background-color: transparent;
      background-image: none
    }

    ::-webkit-inner-spin-button,
    ::-webkit-outer-spin-button {
      height: auto
    }

    ::-webkit-search-decoration {
      -webkit-appearance: none
    }

    ::-webkit-file-upload-button {
      -webkit-appearance: button;
      font: inherit
    }

    h1,
    h3,
    h4,
    p {
      margin: 0
    }

    ol {
      list-style: none;
      margin: 0
    }

    button {
      cursor: pointer
    }

    :disabled {
      cursor: default
    }

    img,
    svg {
      display: block;
      vertical-align: middle
    }

    img {
      max-width: 100%
    }

    :root {
      --background: 0 0% 100%;
      --foreground: 222.2 84% 4.9%;
      --card: 0 0% 100%;
      --card-foreground: 222.2 84% 4.9%;
      --popover: 0 0% 100%;
      --popover-foreground: 222.2 84% 4.9%;
      --primary: 222.2 47.4% 11.2%;
      --primary-foreground: 210 40% 98%;
      --secondary: 210 40% 96.1%;
      --secondary-foreground: 222.2 47.4% 11.2%;
      --muted: 210 40% 96.1%;
      --muted-foreground: 215.4 16.3% 46.9%;
      --accent: 210 40% 96.1%;
      --accent-foreground: 222.2 47.4% 11.2%;
      --destructive: 0 84.2% 60.2%;
      --destructive-foreground: 210 40% 98%;
      --border: 214.3 31.8% 91.4%;
      --input: 214.3 31.8% 91.4%;
      --ring: 222.2 84% 4.9%;
      --radius: .5rem;
      --sidebar-background: 0 0% 98%;
      --sidebar-foreground: 240 5.3% 26.1%;
      --sidebar-primary: 240 5.9% 10%;
      --sidebar-primary-foreground: 0 0% 98%;
      --sidebar-accent: 240 4.8% 95.9%;
      --sidebar-accent-foreground: 240 5.9% 10%;
      --sidebar-border: 220 13% 91%;
      --sidebar-ring: 217.2 91.2% 59.8%
    }

    * {
      border-color: hsl(var(--border))
    }

    body {
      background-color: hsl(var(--background));
      color: hsl(var(--foreground))
    }

    .fixed {
      position: fixed
    }

    .absolute {
      position: absolute
    }

    .relative {
      position: relative
    }

    .inset-0 {
      top: 0;
      right: 0;
      bottom: 0;
      left: 0
    }

    .left-3 {
      left: .75rem
    }

    .right-3 {
      right: .75rem
    }

    .top-0 {
      top: 0
    }

    .top-3 {
      top: .75rem
    }

    .z-10 {
      z-index: 10
    }

    .z-20 {
      z-index: 20
    }

    .z-\[100\] {
      z-index: 100
    }

    .partner-mx-auto {
      margin-left: auto;
      margin-right: auto
    }

    .mb-1 {
      margin-bottom: .25rem
    }

    .mb-12 {
      margin-bottom: 3rem
    }

    .mb-16 {
      margin-bottom: 4rem
    }

    .mb-3 {
      margin-bottom: .75rem
    }

    .mb-4 {
      margin-bottom: 1rem
    }

    .mb-6 {
      margin-bottom: 1.5rem
    }

    .ml-auto {
      margin-left: auto
    }

    .mr-2 {
      margin-right: .5rem
    }

    .mt-2 {
      margin-top: .5rem
    }

    .line-clamp-1 {
      overflow: hidden;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 1
    }

    .line-clamp-3 {
      overflow: hidden;
      display: -webkit-box;
      -webkit-box-orient: vertical;
      -webkit-line-clamp: 3
    }

    .flex {
      display: flex
    }

    .inline-flex {
      display: inline-flex
    }

    .grid {
      display: grid
    }

    .h-1\.5 {
      height: .375rem
    }

    .h-10 {
      height: 2.5rem
    }

    .h-12 {
      height: 3rem
    }

    .h-14 {
      height: 3.5rem
    }

    .h-3 {
      height: .75rem
    }

    .h-3\.5 {
      height: .875rem
    }

    .h-4 {
      height: 1rem
    }

    .max-h-screen {
      max-height: 100vh
    }

    .min-h-screen {
      min-height: 100vh
    }

    .w-1\.5 {
      width: .375rem
    }

    .w-12 {
      width: 3rem
    }

    .w-14 {
      width: 3.5rem
    }

    .w-3 {
      width: .75rem
    }

    .w-3\.5 {
      width: .875rem
    }

    .w-4 {
      width: 1rem
    }

    .w-full {
      width: 100%
    }

    .min-w-0 {
      min-width: 0px
    }

    .max-w-2xl {
      max-width: 42rem
    }

    .max-w-3xl {
      max-width: 48rem
    }

    .partner-max-w-7xl {
      max-width: 80rem
    }

    .flex-1 {
      flex: 1 1 0%
    }

    .flex-shrink-0 {
      flex-shrink: 0
    }

    @keyframes pulse {
      50% {
        opacity: .5
      }
    }

    .partner-grid-cols-1 {
      grid-template-columns: repeat(1, minmax(0, 1fr))
    }

    .partner-flex-col {
      flex-direction: column
    }

    .partner-flex-ndl-reverse {
      flex-direction: column-reverse
    }

    .partner-flex-wrap {
      flex-wrap: wrap
    }

    .partner-items-start {
      align-items: flex-start
    }

    .partner-items-center {
      align-items: center
    }

    .justify-center {
      justify-content: center
    }

    .justify-between {
      justify-content: space-between
    }

    .gap-1 {
      gap: .25rem
    }

    .gap-2 {
      gap: .5rem
    }

    .gap-3 {
      gap: .75rem
    }

    .gap-4 {
      gap: 1rem
    }

    .gap-6 {
      gap: 1.5rem
    }

    .space-y-1\.5>:not([hidden])~:not([hidden]) {
      --tw-space-y-reverse: 0;
      margin-top: calc(.375rem*calc(1 - var(--tw-space-y-reverse)));
      margin-bottom: calc(.375rem*var(--tw-space-y-reverse))
    }

    .space-y-2>:not([hidden])~:not([hidden]) {
      --tw-space-y-reverse: 0;
      margin-top: calc(.5rem*calc(1 - var(--tw-space-y-reverse)));
      margin-bottom: calc(.5rem*var(--tw-space-y-reverse))
    }

    .space-y-4>:not([hidden])~:not([hidden]) {
      --tw-space-y-reverse: 0;
      margin-top: calc(1rem*calc(1 - var(--tw-space-y-reverse)));
      margin-bottom: calc(1rem*var(--tw-space-y-reverse))
    }

    .overflow-hidden {
      overflow: hidden
    }

    .whitespace-nowrap {
      white-space: nowrap
    }

    .rounded-2xl {
      border-radius: 1rem
    }

    .rounded-full {
      border-radius: 9999px
    }

    .rounded-lg {
      border-radius: var(--radius)
    }

    .rounded-md {
      border-radius: calc(var(--radius) - 2px)
    }

    .rounded-xl {
      border-radius: .75rem
    }

    .border {
      border-width: 1px
    }

    .border-0 {
      border-width: 0px
    }

    .border-gray-600 {
      --tw-border-opacity: 1;
      border-color: rgb(75 85 99/var(--tw-border-opacity, 1))
    }

    .border-gray-700\/30 {
      border-color: #3741514d
    }

    .border-gray-700\/50 {
      border-color: #37415180
    }

    .border-gray-800\/50 {
      border-color: #1f293780
    }

    .border-transparent {
      border-color: transparent
    }

    .bg-gray-800\/50 {
      background-color: #1f293780
    }

    .bg-gray-800\/90 {
      background-color: #1f2937e6
    }

    .bg-gray-900\/60 {
      background-color: #11182799
    }

    .bg-gray-900\/80 {
      background-color: #111827cc
    }

    .bg-primary {
      background-color: hsl(var(--primary))
    }

    .bg-\[radial-gradient\(circle_at_50\%_50\%\,rgba\(59\,130\,246\,0\.08\)\,transparent_70\%\)\] {
      background-image: radial-gradient(circle at 50% 50%, rgba(59, 130, 246, .08), transparent 70%)
    }

    .bg-gradient-to-br {
      background-image: linear-gradient(to bottom right, var(--tw-gradient-stops))
    }

    .bg-gradient-to-r {
      background-image: linear-gradient(to right, var(--tw-gradient-stops))
    }

    .from-blue-400 {
      --tw-gradient-from: #60a5fa var(--tw-gradient-from-position)
    }

    .from-blue-600 {
      --tw-gradient-from: #2563eb var(--tw-gradient-from-position);
      --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
    }

    .from-blue-600\/5 {
      --tw-gradient-from: rgb(37 99 235/.05) var(--tw-gradient-from-position)
    }

    .from-emerald-600 {
      --tw-gradient-from: #059669 var(--tw-gradient-from-position)
    }

    .from-gray-900 {
      --tw-gradient-from: #111827 var(--tw-gradient-from-position)
    }

    .from-gray-900\/80 {
      --tw-gradient-from: rgb(17 24 39/.8) var(--tw-gradient-from-position);
      --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
    }

    .from-gray-950 {
      --tw-gradient-from: #030712 var(--tw-gradient-from-position)
    }

    .from-purple-600 {
      --tw-gradient-from: #9333ea var(--tw-gradient-from-position)
    }

    .from-white {
      --tw-gradient-from: #fff var(--tw-gradient-from-position)
    }

    .via-blue-500 {
      --tw-gradient-stops: var(--tw-gradient-from), #3b82f6 var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .via-gray-100 {
      --tw-gradient-stops: var(--tw-gradient-from), #f3f4f6 var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .via-gray-800 {
      --tw-gradient-stops: var(--tw-gradient-from), #1f2937 var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .via-gray-900 {
      --tw-gradient-stops: var(--tw-gradient-from), #111827 var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .via-green-500 {
      --tw-gradient-stops: var(--tw-gradient-from), #22c55e var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .via-purple-400 {
      --tw-gradient-stops: var(--tw-gradient-from), #c084fc var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .via-purple-500 {
      --tw-gradient-stops: var(--tw-gradient-from), #a855f7 var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .via-purple-600 {
      --tw-gradient-stops: var(--tw-gradient-from), #9333ea var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .via-purple-600\/5 {
      --tw-gradient-stops: var(--tw-gradient-from), rgb(147 51 234/.05) var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .to-black {
      --tw-gradient-to: #000 var(--tw-gradient-to-position)
    }

    .to-cyan-500 {
      --tw-gradient-to: #06b6d4 var(--tw-gradient-to-position)
    }

    .to-gray-300 {
      --tw-gradient-to: #d1d5db var(--tw-gradient-to-position)
    }

    .to-gray-800\/80 {
      --tw-gradient-to: rgb(31 41 55/.8) var(--tw-gradient-to-position)
    }

    .to-green-600\/5 {
      --tw-gradient-to: rgb(22 163 74/.05) var(--tw-gradient-to-position)
    }

    .to-pink-400 {
      --tw-gradient-to: #f472b6 var(--tw-gradient-to-position)
    }

    .to-pink-500 {
      --tw-gradient-to: #ec4899 var(--tw-gradient-to-position)
    }

    .to-pink-600 {
      --tw-gradient-to: #db2777 var(--tw-gradient-to-position)
    }

    .to-purple-600 {
      --tw-gradient-to: #9333ea var(--tw-gradient-to-position)
    }

    .to-teal-500 {
      --tw-gradient-to: #14b8a6 var(--tw-gradient-to-position)
    }

    .bg-clip-text {
      -webkit-background-clip: text;
      background-clip: text
    }

    .fill-current {
      fill: currentColor
    }

    .object-contain {
      -o-object-fit: contain;
      object-fit: contain
    }

    .p-4 {
      padding: 1rem
    }

    .p-6 {
      padding: 1.5rem
    }

    .p-8 {
      padding: 2rem
    }

    .px-2 {
      padding-left: .5rem;
      padding-right: .5rem
    }

    .px-3 {
      padding-left: .75rem;
      padding-right: .75rem
    }

    .px-4 {
      padding-left: 1rem;
      padding-right: 1rem
    }

    .partner-px-6 {
      padding-left: 1.5rem;
      padding-right: 1.5rem
    }

    .py-0\.5 {
      padding-top: .125rem;
      padding-bottom: .125rem
    }

    .py-1 {
      padding-top: .25rem;
      padding-bottom: .25rem
    }

    .py-1\.5 {
      padding-top: .375rem;
      padding-bottom: .375rem
    }

    .py-16 {
      padding-top: 4rem;
      padding-bottom: 4rem
    }

    .py-2\.5 {
      padding-top: .625rem;
      padding-bottom: .625rem
    }

    .py-3 {
      padding-top: .75rem;
      padding-bottom: .75rem
    }

    .pb-4 {
      padding-bottom: 1rem
    }

    .pb-6 {
      padding-bottom: 1.5rem
    }

    .pt-0 {
      padding-top: 0
    }

    .pt-12 {
      padding-top: 3rem
    }

    .pt-3 {
      padding-top: .75rem
    }

    .text-center {
      text-align: center
    }

    .text-2xl {
      font-size: 1.5rem;
      line-height: 2rem
    }

    .text-3xl {
      font-size: 1.875rem;
      line-height: 2.25rem
    }

    .partner-text-4xl {
      font-size: 2.25rem
    }

    .text-lg {
      font-size: 1.125rem
    }

    .text-sm {
      font-size: .875rem;
      line-height: 1.25rem
    }

    .text-xl {
      font-size: 1.25rem;
      line-height: 1.75rem
    }

    .text-xs {
      font-size: .75rem;
      line-height: 1rem
    }

    .font-black {
      font-weight: 900
    }

    .font-bold {
      font-weight: 700
    }

    .font-medium {
      font-weight: 500
    }

    .font-semibold {
      font-weight: 600
    }

    .leading-relaxed {
      line-height: 1.625
    }

    .leading-tight {
      line-height: 1.25
    }

    .tracking-tight {
      letter-spacing: -.025em
    }

    .text-blue-400 {
      --tw-text-opacity: 1;
      color: rgb(96 165 250/var(--tw-text-opacity, 1))
    }

    .text-card-foreground {
      color: hsl(var(--card-foreground))
    }

    .text-gray-300 {
      --tw-text-opacity: 1;
      color: rgb(209 213 219/var(--tw-text-opacity, 1))
    }

    .text-gray-400 {
      --tw-text-opacity: 1;
      color: rgb(156 163 175/var(--tw-text-opacity, 1))
    }

    .text-gray-500 {
      --tw-text-opacity: 1;
      color: rgb(107 114 128/var(--tw-text-opacity, 1))
    }

    .text-green-400 {
      --tw-text-opacity: 1;
      color: rgb(74 222 128/var(--tw-text-opacity, 1))
    }

    .text-transparent {
      color: transparent
    }

    .text-white {
      --tw-text-opacity: 1;
      color: rgb(255 255 255/var(--tw-text-opacity, 1))
    }

    .text-yellow-400 {
      --tw-text-opacity: 1;
      color: rgb(250 204 21/var(--tw-text-opacity, 1))
    }

    .opacity-0 {
      opacity: 0
    }

    .shadow-sm {
      --tw-shadow: 0 1px 2px 0 rgb(0 0 0/.05);
      --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
      box-shadow: var(--tw-ring-offset-shadow, 0 0#0000), var(--tw-ring-shadow, 0 0#0000), var(--tw-shadow)
    }

    .ring-offset-background {
      --tw-ring-offset-color: hsl(var(--background))
    }

    .backdrop-blur-sm {
      --tw-backdrop-blur: blur(4px);
      -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-xl {
      --tw-backdrop-blur: blur(24px);
      -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-all {
      transition-property: all;
      transition-timing-function: cubic-bezier(.4, 0, .2, 1)
    }

    .transition-colors {
      transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
      transition-timing-function: cubic-bezier(.4, 0, .2, 1);
      transition-duration: .15s
    }

    .transition-opacity {
      transition-property: opacity;
      transition-timing-function: cubic-bezier(.4, 0, .2, 1)
    }

    .transition-transform {
      transition-property: transform;
      transition-timing-function: cubic-bezier(.4, 0, .2, 1)
    }

    .duration-300 {
      transition-duration: .3s
    }

    .duration-500 {
      transition-duration: .5s
    }

    @keyframes enter {
      0% {
        opacity: var(--tw-enter-opacity, 1);
        transform: translate3d(var(--tw-enter-translate-x, 0), var(--tw-enter-translate-y, 0), 0) scale3d(var(--tw-enter-scale, 1), var(--tw-enter-scale, 1), var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))
      }
    }

    @keyframes exit {
      to {
        opacity: var(--tw-exit-opacity, 1);
        transform: translate3d(var(--tw-exit-translate-x, 0), var(--tw-exit-translate-y, 0), 0) scale3d(var(--tw-exit-scale, 1), var(--tw-exit-scale, 1), var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))
      }
    }

    .duration-300 {
      animation-duration: .3s
    }

    .duration-500 {
      animation-duration: .5s
    }

    .hover\:scale-105:hover {
      --tw-scale-x: 1.05;
      --tw-scale-y: 1.05;
    }

    .hover\:scale-\[1\.02\]:hover {
      --tw-scale-x: 1.02;
      --tw-scale-y: 1.02;
      transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
    }

    .hover\:border-gray-500:hover {
      --tw-border-opacity: 1;
      border-color: rgb(107 114 128/var(--tw-border-opacity, 1))
    }

    .hover\:border-gray-700:hover {
      --tw-border-opacity: 1;
      border-color: rgb(55 65 81/var(--tw-border-opacity, 1))
    }

    .hover\:bg-gray-700\/70:hover {
      background-color: #374151b3
    }

    .hover\:bg-primary\/80:hover {
      background-color: hsl(var(--primary)/.8)
    }

    .hover\:bg-primary\/90:hover {
      background-color: hsl(var(--primary)/.9)
    }

    .hover\:from-blue-700:hover {
      --tw-gradient-from: #1d4ed8 var(--tw-gradient-from-position);
      --tw-gradient-to: rgb(29 78 216/0) var(--tw-gradient-to-position);
      --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
    }

    .hover\:via-purple-700:hover {
      --tw-gradient-to: rgb(126 34 206/0) var(--tw-gradient-to-position);
      --tw-gradient-stops: var(--tw-gradient-from), #7e22ce var(--tw-gradient-via-position), var(--tw-gradient-to)
    }

    .hover\:to-pink-700:hover {
      --tw-gradient-to: #be185d var(--tw-gradient-to-position)
    }

    .hover\:text-white:hover {
      --tw-text-opacity: 1;
      color: rgb(255 255 255/var(--tw-text-opacity, 1))
    }

    .hover\:opacity-90:hover {
      opacity: .9
    }

    .hover\:shadow-xl:hover {
      --tw-shadow: 0 20px 25px -5px rgb(0 0 0/.1), 0 8px 10px -6px rgb(0 0 0/.1);
      --tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
      box-shadow: var(--tw-ring-offset-shadow, 0 0#0000), var(--tw-ring-shadow, 0 0#0000), var(--tw-shadow)
    }

    .hover\:shadow-purple-500\/10:hover {
      --tw-shadow-color: rgb(168 85 247/.1);
      --tw-shadow: var(--tw-shadow-colored)
    }

    .focus\:outline-none:focus {
      outline: 2px solid transparent;
      outline-offset: 2px
    }

    .focus\:ring-2:focus {
      --tw-ring-offset-shadow: var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
      --tw-ring-shadow: var(--tw-ring-inset)0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
      box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0#0000)
    }

    .focus\:ring-ring:focus {
      --tw-ring-color: hsl(var(--ring))
    }

    .focus\:ring-offset-2:focus {
      --tw-ring-offset-width: 2px
    }

    .focus-visible\:outline-none:focus-visible {
      outline: 2px solid transparent;
      outline-offset: 2px
    }

    .focus-visible\:ring-2:focus-visible {
      --tw-ring-offset-shadow: var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
      --tw-ring-shadow: var(--tw-ring-inset)0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
      box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0#0000)
    }

    .focus-visible\:ring-ring:focus-visible {
      --tw-ring-color: hsl(var(--ring))
    }

    .focus-visible\:ring-offset-2:focus-visible {
      --tw-ring-offset-width: 2px
    }

    .disabled\:pointer-events-none:disabled {
      pointer-events: none
    }

    .disabled\:opacity-50:disabled {
      opacity: .5
    }

    .group:hover .group-hover\:scale-105 {
      --tw-scale-x: 1.05;
      --tw-scale-y: 1.05;
      transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
    }

    .group:hover .group-hover\:bg-gradient-to-r {
      background-image: linear-gradient(to right, var(--tw-gradient-stops))
    }

    .group:hover .group-hover\:from-blue-400 {
      --tw-gradient-from: #60a5fa var(--tw-gradient-from-position);
      --tw-gradient-to: rgb(96 165 250/0) var(--tw-gradient-to-position);
      --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)
    }

    .group:hover .group-hover\:to-purple-400 {
      --tw-gradient-to: #c084fc var(--tw-gradient-to-position)
    }

    .group:hover .group-hover\:bg-clip-text {
      -webkit-background-clip: text;
      background-clip: text
    }

    .group:hover .group-hover\:text-transparent {
      color: transparent
    }

    .group:hover .group-hover\:opacity-5 {
      opacity: .05
    }

    @keyframes accordion-up {
      0% {
        height: var(--radix-accordion-content-height)
      }

      to {
        height: 0
      }
    }

    @keyframes accordion-down {
      0% {
        height: 0
      }

      to {
        height: var(--radix-accordion-content-height)
      }
    }

    @media (min-width:640px) {
      .sm\:bottom-0 {
        bottom: 0
      }

      .sm\:right-0 {
        right: 0
      }

      .sm\:top-auto {
        top: auto
      }

      .sm\:flex-row {
        flex-direction: row
      }

      .sm\:partner-flex-col {
        flex-direction: column
      }

      .sm\:partner-px-6 {
        padding-left: 1.5rem;
        padding-right: 1.5rem
      }
    }

    @media (min-width:768px) {
      .md\:max-w-\[420px\] {
        max-width: 420px
      }

      .md\:partner-grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
      }

      .md\:partner-text-4xl {
        font-size: 2.25rem;
        line-height: 2.5rem
      }

      .md\:partner-text-5xl {
        font-size: 3rem;
        line-height: 1
      }
    }

    @media (min-width:1024px) {
      .lg\:partner-grid-cols-3 {
        grid-template-columns: repeat(3, minmax(0, 1fr))
      }

      .lg\:px-8 {
        padding-left: 2rem;
        padding-right: 2rem
      }

      .lg\:text-6xl {
        font-size: 3.75rem;
        line-height: 1
      }
    }

    .\[\&_svg\]\:pointer-events-none svg {
      pointer-events: none
    }

    .\[\&_svg\]\:size-4 svg {
      width: 1rem;
      height: 1rem
    }

    .\[\&_svg\]\:shrink-0 svg {
      flex-shrink: 0
    }
  </style>
  <style>
    #lovable-badge {
      position: fixed;
      bottom: 10px;
      right: 10px;
      width: 141px;
      padding: 5px 13px;
      background-color: #000;
      color: #fff;
      font-size: 12px;
      border-radius: 5px;
      font-family: sans-serif;
      display: flex;
      align-items: center;
      gap: 4px;
      z-index: 1000000;
      text-transform: none !important;
      font-feature-settings: normal !important;
      font-weight: 400 !important
    }
  </style>
  <style>
    :where(html[dir="ltr"]),
    :where([data-sonner-toaster][dir="ltr"]) {
      --toast-icon-margin-start: -3px;
      --toast-icon-margin-end: 4px;
      --toast-svg-margin-start: -1px;
      --toast-svg-margin-end: 0px;
      --toast-button-margin-start: auto;
      --toast-button-margin-end: 0;
      --toast-close-button-start: 0;
      --toast-close-button-end: unset;
      --toast-close-button-transform: translate(-35%, -35%)
    }

    :where(html[dir="rtl"]),
    :where([data-sonner-toaster][dir="rtl"]) {
      --toast-icon-margin-start: 4px;
      --toast-icon-margin-end: -3px;
      --toast-svg-margin-start: 0px;
      --toast-svg-margin-end: -1px;
      --toast-button-margin-start: 0;
      --toast-button-margin-end: auto;
      --toast-close-button-start: unset;
      --toast-close-button-end: 0;
      --toast-close-button-transform: translate(35%, -35%)
    }

    :where([data-sonner-toaster]) {
      position: fixed;
      width: var(--width);
      font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica Neue, Arial, Noto Sans, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
      --gray1: hsl(0, 0%, 99%);
      --gray2: hsl(0, 0%, 97.3%);
      --gray3: hsl(0, 0%, 95.1%);
      --gray4: hsl(0, 0%, 93%);
      --gray5: hsl(0, 0%, 90.9%);
      --gray6: hsl(0, 0%, 88.7%);
      --gray7: hsl(0, 0%, 85.8%);
      --gray8: hsl(0, 0%, 78%);
      --gray9: hsl(0, 0%, 56.1%);
      --gray10: hsl(0, 0%, 52.3%);
      --gray11: hsl(0, 0%, 43.5%);
      --gray12: hsl(0, 0%, 9%);
      --border-radius: 8px;
      box-sizing: border-box;
      padding: 0;
      margin: 0;
      list-style: none;
      outline: none;
      z-index: 999999999
    }

    :where([data-sonner-toaster][data-x-position="right"]) {
      right: max(var(--offset), env(safe-area-inset-right))
    }

    :where([data-sonner-toaster][data-x-position="left"]) {
      left: max(var(--offset), env(safe-area-inset-left))
    }

    :where([data-sonner-toaster][data-x-position="center"]) {
      left: 50%;
      transform: translate(-50%)
    }

    :where([data-sonner-toaster][data-y-position="top"]) {
      top: max(var(--offset), env(safe-area-inset-top))
    }

    :where([data-sonner-toaster][data-y-position="bottom"]) {
      bottom: max(var(--offset), env(safe-area-inset-bottom))
    }

    :where([data-sonner-toast]) {
      --y: translateY(100%);
      --lift-amount: calc(var(--lift)*var(--gap));
      z-index: var(--z-index);
      position: absolute;
      opacity: 0;
      transform: var(--y);
      filter: blur(0);
      touch-action: none;
      transition: transform .4s, opacity .4s, height .4s, box-shadow .2s;
      box-sizing: border-box;
      outline: none;
      overflow-wrap: anywhere
    }

    :where([data-sonner-toast][data-styled="true"]) {
      padding: 16px;
      background: var(--normal-bg);
      border: 1px solid var(--normal-border);
      color: var(--normal-text);
      border-radius: var(--border-radius);
      box-shadow: 0 4px 12px #0000001a;
      width: var(--width);
      font-size: 13px;
      display: flex;
      align-items: center;
      gap: 6px
    }

    :where([data-sonner-toast]:focus-visible) {
      box-shadow: 0 4px 12px #0000001a, 0 0 0 2px #0003
    }

    :where([data-sonner-toast][data-y-position="top"]) {
      top: 0;
      --y: translateY(-100%);
      --lift: 1;
      --lift-amount: calc(1*var(--gap))
    }

    :where([data-sonner-toast][data-y-position="bottom"]) {
      bottom: 0;
      --y: translateY(100%);
      --lift: -1;
      --lift-amount: calc(var(--lift)*var(--gap))
    }

    :where([data-sonner-toast]) :where([data-description]) {
      font-weight: 400;
      line-height: 1.4;
      color: inherit
    }

    :where([data-sonner-toast]) :where([data-title]) {
      font-weight: 500;
      line-height: 1.5;
      color: inherit
    }

    :where([data-sonner-toast]) :where([data-icon]) {
      display: flex;
      height: 16px;
      width: 16px;
      position: relative;
      justify-content: flex-start;
      align-items: center;
      flex-shrink: 0;
      margin-left: var(--toast-icon-margin-start);
      margin-right: var(--toast-icon-margin-end)
    }

    :where([data-sonner-toast][data-promise="true"]) :where([data-icon])>svg {
      opacity: 0;
      transform: scale(.8);
      transform-origin: center;
      animation: sonner-fade-in .3s ease forwards
    }

    :where([data-sonner-toast]) :where([data-icon])>* {
      flex-shrink: 0
    }

    :where([data-sonner-toast]) :where([data-icon]) svg {
      margin-left: var(--toast-svg-margin-start);
      margin-right: var(--toast-svg-margin-end)
    }

    :where([data-sonner-toast]) :where([data-content]) {
      display: flex;
      flex-direction: column;
      gap: 2px
    }

    :where([data-sonner-toast]) :where([data-button]):focus-visible {
      box-shadow: 0 0 0 2px #0006
    }

    :where([data-sonner-toast]) :where([data-button]):first-of-type {
      margin-left: var(--toast-button-margin-start);
      margin-right: var(--toast-button-margin-end)
    }

    :where([data-sonner-toast]) :where([data-cancel]) {
      color: var(--normal-text);
      background: rgba(0, 0, 0, .08)
    }

    :where([data-sonner-toast][data-theme="dark"]) :where([data-cancel]) {
      background: rgba(255, 255, 255, .3)
    }

    :where([data-sonner-toast]) :where([data-close-button]) {
      position: absolute;
      left: var(--toast-close-button-start);
      right: var(--toast-close-button-end);
      top: 0;
      height: 20px;
      width: 20px;
      display: flex;
      justify-content: center;
      align-items: center;
      padding: 0;
      background: var(--gray1);
      color: var(--gray12);
      border: 1px solid var(--gray4);
      transform: var(--toast-close-button-transform);
      border-radius: 50%;
      cursor: pointer;
      z-index: 1;
      transition: opacity .1s, background .2s, border-color .2s
    }

    :where([data-sonner-toast]) :where([data-close-button]):focus-visible {
      box-shadow: 0 4px 12px #0000001a, 0 0 0 2px #0003
    }

    :where([data-sonner-toast]) :where([data-disabled="true"]) {
      cursor: not-allowed
    }

    :where([data-sonner-toast]):hover :where([data-close-button]):hover {
      background: var(--gray2);
      border-color: var(--gray5)
    }

    :where([data-sonner-toast][data-swiping="true"]):before {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      height: 100%;
      z-index: -1
    }

    :where([data-sonner-toast][data-y-position="top"][data-swiping="true"]):before {
      bottom: 50%;
      transform: scaleY(3) translateY(50%)
    }

    :where([data-sonner-toast][data-y-position="bottom"][data-swiping="true"]):before {
      top: 50%;
      transform: scaleY(3) translateY(-50%)
    }

    :where([data-sonner-toast][data-swiping="false"][data-removed="true"]):before {
      content: "";
      position: absolute;
      inset: 0;
      transform: scaleY(2)
    }

    :where([data-sonner-toast]):after {
      content: "";
      position: absolute;
      left: 0;
      height: calc(var(--gap) + 1px);
      bottom: 100%;
      width: 100%
    }

    :where([data-sonner-toast][data-mounted="true"]) {
      --y: translateY(0);
      opacity: 1
    }

    :where([data-sonner-toast][data-expanded="false"][data-front="false"]) {
      --scale: var(--toasts-before)*.05 + 1;
      --y: translateY(calc(var(--lift-amount)*var(--toasts-before))) scale(calc(-1*var(--scale)));
      height: var(--front-toast-height)
    }

    :where([data-sonner-toast])>* {
      transition: opacity .4s
    }

    :where([data-sonner-toast][data-expanded="false"][data-front="false"][data-styled="true"])>* {
      opacity: 0
    }

    :where([data-sonner-toast][data-visible="false"]) {
      opacity: 0;
      pointer-events: none
    }

    :where([data-sonner-toast][data-mounted="true"][data-expanded="true"]) {
      --y: translateY(calc(var(--lift)*var(--offset)));
      height: var(--initial-height)
    }

    :where([data-sonner-toast][data-removed="true"][data-front="true"][data-swipe-out="false"]) {
      --y: translateY(calc(var(--lift)*-100%));
      opacity: 0
    }

    :where([data-sonner-toast][data-removed="true"][data-front="false"][data-swipe-out="false"][data-expanded="true"]) {
      --y: translateY(calc(var(--lift)*var(--offset) + var(--lift)*-100%));
      opacity: 0
    }

    :where([data-sonner-toast][data-removed="true"][data-front="false"][data-swipe-out="false"][data-expanded="false"]) {
      --y: translateY(40%);
      opacity: 0;
      transition: transform .5s, opacity .2s
    }

    :where([data-sonner-toast][data-removed="true"][data-front="false"]):before {
      height: calc(var(--initial-height) + 20%)
    }

    @keyframes swipe-out {
      0% {
        transform: translateY(calc(var(--lift)*var(--offset) + var(--swipe-amount)));
        opacity: 1
      }

      to {
        transform: translateY(calc(var(--lift)*var(--offset) + var(--swipe-amount) + var(--lift)*-100%));
        opacity: 0
      }
    }

    @media (max-width:600px) {}

    @keyframes sonner-fade-in {
      0% {
        opacity: 0;
        transform: scale(.8)
      }

      to {
        opacity: 1;
        transform: scale(1)
      }
    }

    @keyframes sonner-fade-out {
      0% {
        opacity: 1;
        transform: scale(1)
      }

      to {
        opacity: 0;
        transform: scale(.8)
      }
    }

    @keyframes sonner-spin {
      0% {
        opacity: 1
      }

      to {
        opacity: .15
      }
    }

    @media (prefers-reduced-motion) {}