/* ! tailwindcss v3.4.1 | MIT License | https://tailwindcss.com */

*,

:before,

:after {

  box-sizing: border-box;

  border-width: 0;

  border-style: solid;

  border-color: hsl(0, 0%, 80%);

}

:before,

:after {

  --tw-content: '';

}

html,

:host {

  line-height: 1.5;

  -webkit-text-size-adjust: 100%;

  -moz-tab-size: 4;

  tab-size: 4;

  font-family: 'DM Sans', sans-serif;

  font-feature-settings: normal;

  font-variation-settings: normal;

  -webkit-tap-highlight-color: transparent;

}

body {

  margin: 0;

  line-height: inherit;

}

hr {

  height: 0;

  color: inherit;

  border-top-width: 1px;

}

abbr:where([title]) {

  text-decoration: underline dotted;

}

h1,

h2,

h3,

h4,

h5,

h6 {

  font-size: inherit;

  font-weight: inherit;

}

a {

  color: inherit;

  text-decoration: inherit;

}

b,

strong {

  font-weight: bolder;

}

code,

kbd,

samp,

pre {

  font-family: 'IBM Plex Mono', monospace;

  font-feature-settings: normal;

  font-variation-settings: normal;

  font-size: 1em;

}

small {

  font-size: 80%;

}

sub,

sup {

  font-size: 75%;

  line-height: 0;

  position: relative;

  vertical-align: baseline;

}

sub {

  bottom: -0.25em;

}

sup {

  top: -0.5em;

}

table {

  text-indent: 0;

  border-color: inherit;

  border-collapse: collapse;

}

button,

input,

optgroup,

select,

textarea {

  font-family: inherit;

  font-feature-settings: inherit;

  font-variation-settings: inherit;

  font-size: 100%;

  font-weight: inherit;

  line-height: inherit;

  color: inherit;

  margin: 0;

  padding: 0;

}

button,

select {

  text-transform: none;

}

button,

[type='button'],

[type='reset'],

[type='submit'] {

  -webkit-appearance: button;

  background-color: transparent;

  background-image: none;

}

:-moz-focusring {

  outline: auto;

}

:-moz-ui-invalid {

  box-shadow: none;

}

progress {

  vertical-align: baseline;

}

::-webkit-inner-spin-button,

::-webkit-outer-spin-button {

  height: auto;

}

[type='search'] {

  -webkit-appearance: textfield;

  outline-offset: -2px;

}

::-webkit-search-decoration {

  -webkit-appearance: none;

}

::-webkit-file-upload-button {

  -webkit-appearance: button;

  font: inherit;

}

summary {

  display: list-item;

}

blockquote,

dl,

dd,

h1,

h2,

h3,

h4,

h5,

h6,

hr,

figure,

p,

pre {

  margin: 0;

}

fieldset {

  margin: 0;

  padding: 0;

}

legend {

  padding: 0;

}

ol,

ul,

menu {

  list-style: none;

  margin: 0;

  padding: 0;

}

dialog {

  padding: 0;

}

textarea {

  resize: vertical;

}

input::placeholder,

textarea::placeholder {

  opacity: 1;

  color: hsl(0, 0%, 60%);

}

button,

[role='button'] {

  cursor: pointer;

}

:disabled {

  cursor: default;

}

img,

svg,

video,

canvas,

audio,

iframe,

embed,

object {

  display: block;

  vertical-align: middle;

}

img,

video {

  max-width: 100%;

  height: auto;

}

[hidden] {

  display: none;

}

*,

::before,

::after {

  --tw-border-spacing-x: 0;

  --tw-border-spacing-y: 0;

  --tw-translate-x: 0;

  --tw-translate-y: 0;

  --tw-rotate: 0;

  --tw-skew-x: 0;

  --tw-skew-y: 0;

  --tw-scale-x: 1;

  --tw-scale-y: 1;

  --tw-pan-x: ;

  --tw-pan-y: ;

  --tw-pinch-zoom: ;

  --tw-scroll-snap-strictness: proximity;

  --tw-gradient-from-position: ;

  --tw-gradient-via-position: ;

  --tw-gradient-to-position: ;

  --tw-ordinal: ;

  --tw-slashed-zero: ;

  --tw-numeric-figure: ;

  --tw-numeric-spacing: ;

  --tw-numeric-fraction: ;

  --tw-ring-inset: ;

  --tw-ring-offset-width: 0px;

  --tw-ring-offset-color: #fff;

  --tw-ring-color: rgb(59 130 246 / 0.5);

  --tw-ring-offset-shadow: 0 0 #0000;

  --tw-ring-shadow: 0 0 #0000;

  --tw-shadow: 0 0 #0000;

  --tw-shadow-colored: 0 0 #0000;

  --tw-blur: ;

  --tw-brightness: ;

  --tw-contrast: ;

  --tw-grayscale: ;

  --tw-hue-rotate: ;

  --tw-invert: ;

  --tw-saturate: ;

  --tw-sepia: ;

  --tw-drop-shadow: ;

  --tw-backdrop-blur: ;

  --tw-backdrop-brightness: ;

  --tw-backdrop-contrast: ;

  --tw-backdrop-grayscale: ;

  --tw-backdrop-hue-rotate: ;

  --tw-backdrop-invert: ;

  --tw-backdrop-opacity: ;

  --tw-backdrop-saturate: ;

  --tw-backdrop-sepia: ;

}

::backdrop {

  --tw-border-spacing-x: 0;

  --tw-border-spacing-y: 0;

  --tw-translate-x: 0;

  --tw-translate-y: 0;

  --tw-rotate: 0;

  --tw-skew-x: 0;

  --tw-skew-y: 0;

  --tw-scale-x: 1;

  --tw-scale-y: 1;

  --tw-pan-x: ;

  --tw-pan-y: ;

  --tw-pinch-zoom: ;

  --tw-scroll-snap-strictness: proximity;

  --tw-gradient-from-position: ;

  --tw-gradient-via-position: ;

  --tw-gradient-to-position: ;

  --tw-ordinal: ;

  --tw-slashed-zero: ;

  --tw-numeric-figure: ;

  --tw-numeric-spacing: ;

  --tw-numeric-fraction: ;

  --tw-ring-inset: ;

  --tw-ring-offset-width: 0px;

  --tw-ring-offset-color: #fff;

  --tw-ring-color: rgb(59 130 246 / 0.5);

  --tw-ring-offset-shadow: 0 0 #0000;

  --tw-ring-shadow: 0 0 #0000;

  --tw-shadow: 0 0 #0000;

  --tw-shadow-colored: 0 0 #0000;

  --tw-blur: ;

  --tw-brightness: ;

  --tw-contrast: ;

  --tw-grayscale: ;

  --tw-hue-rotate: ;

  --tw-invert: ;

  --tw-saturate: ;

  --tw-sepia: ;

  --tw-drop-shadow: ;

  --tw-backdrop-blur: ;

  --tw-backdrop-brightness: ;

  --tw-backdrop-contrast: ;

  --tw-backdrop-grayscale: ;

  --tw-backdrop-hue-rotate: ;

  --tw-backdrop-invert: ;

  --tw-backdrop-opacity: ;

  --tw-backdrop-saturate: ;

  --tw-backdrop-sepia: ;

}

.container {

  width: 100%;

}

@media (min-width: 640px) {

  .container {

    max-width: 640px;

  }

}

@media (min-width: 768px) {

  .container {

    max-width: 768px;

  }

}

@media (min-width: 1024px) {

  .container {

    max-width: 1024px;

  }

}

@media (min-width: 1280px) {

  .container {

    max-width: 1280px;

  }

}

@media (min-width: 1536px) {

  .container {

    max-width: 1536px;

  }

}

.visible {

  visibility: visible;

}

.fixed {

  position: fixed;

}

.left-0 {

  left: 0px;

}

.right-0 {

  right: 0px;

}

.top-0 {

  top: 0px;

}

.top-16 {

  top: 4rem;

}

.z-50 {

  z-index: 50;

}

.mx-auto {

  margin-left: auto;

  margin-right: auto;

}

.mb-1 {

  margin-bottom: 0.25rem;

}

.mb-12 {

  margin-bottom: 3rem;

}

.mb-6 {

  margin-bottom: 1.5rem;

}

.mb-8 {

  margin-bottom: 2rem;

}

.block {

  display: block;

}

.inline-block {

  display: inline-block;

}

.flex {

  display: flex;

}

.hidden {

  display: none;

}

.h-0 {

  height: 0px;

}

.h-0\.5 {

  height: 0.125rem;

}

.h-10 {

  height: 2.5rem;

}

.h-16 {

  height: 4rem;

}

.h-8 {

  height: 2rem;

}

.min-h-screen {

  min-height: 100vh;

}

.w-10 {

  width: 2.5rem;

}

.w-6 {

  width: 1.5rem;

}

.max-w-2xl {

  max-width: 42rem;

}

.max-w-screen-lg {

  max-width: 1024px;

}

.flex-shrink-0 {

  flex-shrink: 0;

}

.transform {

  transform: translate(var(--tw-translate-x), var(--tw-translate-y))

    rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y))

    scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));

}

.flex-col {

  flex-direction: column;

}

.items-center {

  align-items: center;

}

.justify-center {

  justify-content: center;

}

.justify-between {

  justify-content: space-between;

}

.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));

}

.scroll-smooth {

  scroll-behavior: smooth;

}

.rounded {

  border-radius: 0.5rem;

}

.bg-cta-primary {

  --tw-bg-opacity: 1;

  background-color: hsl(0 0% 100% / var(--tw-bg-opacity));

}

.bg-primary {

  --tw-bg-opacity: 1;

  background-color: hsl(0 0% 8% / var(--tw-bg-opacity));

}

.bg-secondary {

  --tw-bg-opacity: 1;

  background-color: hsl(0 0% 14% / var(--tw-bg-opacity));

}

.bg-secondary-foreground {

  --tw-bg-opacity: 1;

  background-color: hsl(0 0% 96% / var(--tw-bg-opacity));

}

.px-6 {

  padding-left: 1.5rem;

  padding-right: 1.5rem;

}

.px-8 {

  padding-left: 2rem;

  padding-right: 2rem;

}

.py-3 {

  padding-top: 0.75rem;

  padding-bottom: 0.75rem;

}

.py-32 {

  padding-top: 8rem;

  padding-bottom: 8rem;

}

.py-4 {

  padding-top: 1rem;

  padding-bottom: 1rem;

}

.py-8 {

  padding-top: 2rem;

  padding-bottom: 2rem;

}

.pt-16 {

  padding-top: 4rem;

}

.text-center {

  text-align: center;

}

.text-2xl {

  font-size: 1.5rem;

  line-height: 2rem;

}

.text-3xl {

  font-size: 1.875rem;

  line-height: 2.25rem;

}

.text-5xl {

  font-size: 3rem;

  line-height: 1;

}

.text-base {

  font-size: 1rem;

  line-height: 1.5rem;

}

.text-sm {

  font-size: 0.875rem;

  line-height: 1.25rem;

}

.font-bold {

  font-weight: 700;

}

.font-light {

  font-weight: 300;

}

.font-medium {

  font-weight: 500;

}

.font-normal {

  font-weight: 400;

}

.leading-relaxed {

  line-height: 1.625;

}

.leading-tight {

  line-height: 1.25;

}

.tracking-tight {

  letter-spacing: -0.025em;

}

.tracking-wide {

  letter-spacing: 0.025em;

}

.tracking-widest {

  letter-spacing: 0.1em;

}

.uppercase {

  text-transform: uppercase;

}

.bg-gray-900 {

  background-color: rgb(17 24 39);

}

.gap-px {

  gap: 1px;

}

.text-cta-primary-foreground {

  --tw-text-opacity: 1;

  color: hsl(0 0% 10% / var(--tw-text-opacity));

}

.text-primary-foreground {

  --tw-text-opacity: 1;

  color: hsl(0 0% 100% / var(--tw-text-opacity));

}

.text-secondary-foreground {

  --tw-text-opacity: 1;

  color: hsl(0 0% 96% / var(--tw-text-opacity));

}

.transition {

  transition-property:

    color, background-color, border-color, text-decoration-color, fill, stroke,

    opacity, box-shadow, transform, filter, backdrop-filter;

  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);

  transition-duration: 150ms;

}

.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-primary-foreground:focus {

  --tw-ring-opacity: 1;

  --tw-ring-color: hsl(0 0% 100% / var(--tw-ring-opacity));

}

.focus\:ring-secondary-foreground:focus {

  --tw-ring-opacity: 1;

  --tw-ring-color: hsl(0 0% 96% / var(--tw-ring-opacity));

}

.focus\:ring-offset-2:focus {

  --tw-ring-offset-width: 2px;

}

.focus\:ring-offset-primary:focus {

  --tw-ring-offset-color: hsl(0, 0%, 8%);

}

.focus\:ring-offset-secondary:focus {

  --tw-ring-offset-color: hsl(0, 0%, 14%);

}

@media (min-width: 1024px) {

  .lg\:flex {

    display: flex;

  }

  .lg\:hidden {

    display: none;

  }

  .lg\:h-10 {

    height: 2.5rem;

  }

  .lg\:h-20 {

    height: 5rem;

  }

  .lg\:items-center {

    align-items: center;

  }

  .lg\:space-x-8 > :not([hidden]) ~ :not([hidden]) {

    --tw-space-x-reverse: 0;

    margin-right: calc(2rem * var(--tw-space-x-reverse));

    margin-left: calc(2rem * calc(1 - var(--tw-space-x-reverse)));

  }

  .lg\:space-x-10 > :not([hidden]) ~ :not([hidden]) {

    --tw-space-x-reverse: 0;

    margin-right: calc(2.5rem * var(--tw-space-x-reverse));

    margin-left: calc(2.5rem * calc(1 - var(--tw-space-x-reverse)));

  }

  .lg\:space-x-12 > :not([hidden]) ~ :not([hidden]) {

    --tw-space-x-reverse: 0;

    margin-right: calc(3rem * var(--tw-space-x-reverse));

    margin-left: calc(3rem * calc(1 - var(--tw-space-x-reverse)));

  }

  .lg\:px-8 {

    padding-left: 2rem;

    padding-right: 2rem;

  }

  .lg\:text-3xl {

    font-size: 1.875rem;

    line-height: 2.25rem;

  }

  .lg\:text-4xl {

    font-size: 2.25rem;

    line-height: 2.5rem;

  }

  .lg\:text-6xl {

    font-size: 3.75rem;

    line-height: 1;

  }

  .lg\:text-5xl {

    font-size: 3rem;

    line-height: 1;

  }

}

.grid {

  display: grid;

}

.grid-cols-1 {

  grid-template-columns: repeat(1, minmax(0, 1fr));

}

.gap-12 {

  gap: 3rem;

}

.aspect-video {

  aspect-ratio: 16 / 9;

}

.overflow-hidden {

  overflow: hidden;

}

.shadow-xl {

  box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);

}

.shadow-2xl {

  box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);

}

.transition-shadow {

  transition-property: box-shadow;

  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);

  transition-duration: 150ms;

}

.duration-300 {

  transition-duration: 300ms;

}

.hover\:shadow-2xl:hover {

  box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);

}

.hover\:underline:hover {

  text-decoration-line: underline;

}

.border-t {

  border-top-width: 1px;

}

.border-gray-800 {

  border-color: rgb(31 41 55);

}

.bg-gray-800 {

  background-color: rgb(31 41 55);

}

.object-cover {

  object-fit: cover;

}

.mb-16 {

  margin-bottom: 4rem;

}

.mb-4 {

  margin-bottom: 1rem;

}

.py-24 {

  padding-top: 6rem;

  padding-bottom: 6rem;

}

.p-8 {

  padding: 2rem;

}

.max-w-screen-xl {

  max-width: 1280px;

}

@media (min-width: 1024px) {

  .lg\:grid-cols-2 {

    grid-template-columns: repeat(2, minmax(0, 1fr));

  }

  .lg\:gap-16 {

    gap: 4rem;

  }

  .lg\:gap-12 {

    gap: 3rem;

  }

}

.gap-8 {

  gap: 2rem;

}

.mb-20 {

  margin-bottom: 5rem;

}

.py-20 {

  padding-top: 5rem;

  padding-bottom: 5rem;

}

.lg\:py-32 {

  padding-top: 8rem;

  padding-bottom: 8rem;

}

.md\:grid-cols-2 {

  grid-template-columns: repeat(2, minmax(0, 1fr));

}

@media (min-width: 768px) {

  .md\:grid-cols-2 {

    grid-template-columns: repeat(2, minmax(0, 1fr));

  }

}

.gap-10 {

  gap: 2.5rem;

}

.lg\:gap-10 {
    gap: 2.5rem;
    }