/*! tailwindcss v4.1.11 | MIT License | https://tailwindcss.com */
html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    overflow-y: scroll;
}
@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-backdrop-blur: initial;
          --tw-backdrop-brightness: initial;
          --tw-backdrop-contrast: initial;
          --tw-backdrop-grayscale: initial;
          --tw-backdrop-hue-rotate: initial;
          --tw-backdrop-invert: initial;
          --tw-backdrop-opacity: initial;
          --tw-backdrop-saturate: initial;
          --tw-backdrop-sepia: initial;
          --tw-duration: initial;
          --tw-ease: initial
      }
  }
}

@layer theme {
  :root,:host {
      --font-sans: ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
      --font-mono: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
      --color-blue-600: oklch(54.6% .245 262.881);
      --color-gray-500: oklch(55.1% .027 264.364);
      --color-black: #000;
      --color-white: #fff;
      --spacing: .25rem;
      --container-xl: 36rem;
      --container-4xl: 56rem;
      --text-sm: .875rem;
      --text-sm--line-height: calc(1.25/.875);
      --text-base: 1rem;
      --text-base--line-height: 1.5 ;
      --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;
      --font-weight-medium: 500;
      --font-weight-semibold: 600;
      --font-weight-bold: 700;
      --tracking-tight: -.025em;
      --leading-tight: 1.25;
      --leading-relaxed: 1.625;
      --radius-lg: .5rem;
      --radius-xl: .75rem;
      --radius-2xl: 1rem;
      --radius-4xl: 2rem;
      --ease-out: cubic-bezier(0,0,.2,1);
      --blur-2xl: 40px;
      --aspect-video: 16/9;
      --default-transition-duration: .15s;
      --default-transition-timing-function: cubic-bezier(.4,0,.2,1);
      --default-font-family: var(--font-sans);
      --default-mono-font-family: var(--font-mono)
  }
}

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

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

  :root {
      --background: 0 0% 100%;
      --foreground: 0 0% 3.9%;
      --card: 0 0% 100%;
      --card-foreground: 0 0% 3.9%;
      --popover: 0 0% 100%;
      --popover-foreground: 0 0% 3.9%;
      --primary: 0 0% 9%;
      --primary-foreground: 0 0% 98%;
      --secondary: 0 0% 96.1%;
      --secondary-foreground: 0 0% 9%;
      --muted: 0 0% 96.1%;
      --muted-foreground: 0 0% 45.1%;
      --accent: 0 0% 96.1%;
      --accent-foreground: 0 0% 9%;
      --destructive: 0 84.2% 60.2%;
      --destructive-foreground: 0 0% 98%;
      --border: 0 0% 89.8%;
      --input: 0 0% 89.8%;
      --ring: 0 0% 3.9%;
      --chart-1: 12 76% 61%;
      --chart-2: 173 58% 39%;
      --chart-3: 197 37% 24%;
      --chart-4: 43 74% 66%;
      --chart-5: 27 87% 67%;
      --radius: .5rem;
      --sidebar-background: 0 0% 98.4%;
      --sidebar-foreground: 240 5.3% 26.1%;
      --sidebar-primary: 240 5.9% 10%;
      --sidebar-primary-foreground: 0 0% 98%;
      --sidebar-accent: 0 0% 90%;
      --sidebar-accent-foreground: 240 5.9% 10%;
      --sidebar-border: 220 13% 91%;
      --sidebar-ring: 217.2 91.2% 59.8%
  }

  .dark {
      --background: 0 0% 3.9%;
      --foreground: 0 0% 98%;
      --card: 0 0% 3.9%;
      --card-foreground: 0 0% 98%;
      --popover: 0 0% 3.9%;
      --popover-foreground: 0 0% 98%;
      --primary: 0 0% 98%;
      --primary-foreground: 0 0% 9%;
      --secondary: 0 0% 14.9%;
      --secondary-foreground: 0 0% 98%;
      --muted: 0 0% 14.9%;
      --muted-foreground: 0 0% 63.9%;
      --accent: 0 0% 14.9%;
      --accent-foreground: 0 0% 98%;
      --destructive: 0 62.8% 30.6%;
      --destructive-foreground: 0 0% 98%;
      --border: 0 0% 14.9%;
      --input: 0 0% 14.9%;
      --ring: 0 0% 83.1%;
      --chart-1: 220 70% 50%;
      --chart-2: 160 60% 45%;
      --chart-3: 30 80% 55%;
      --chart-4: 280 65% 60%;
      --chart-5: 340 75% 55%;
      --sidebar-background: 240 5.9% 10%;
      --sidebar-foreground: 240 4.8% 95.9%;
      --sidebar-primary: 0 0% 0%/0;
      --sidebar-primary-foreground: 0 0% 100%;
      --sidebar-accent: 240 3.7% 15.9%;
      --sidebar-accent-foreground: 240 4.8% 95.9%;
      --sidebar-border: 240 3.7% 15.9%;
      --sidebar-ring: 217.2 91.2% 59.8%
  }
}

@layer components;@layer utilities {
  .visible {
      visibility: visible
  }

  .absolute {
      position: absolute
  }

  .fixed {
      position: fixed
  }

  .relative {
      position: relative
  }

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

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

  .z-0 {
      z-index: 0
  }

  .z-10 {
      z-index: 10
  }

  .z-20 {
      z-index: 20
  }

  .mx-2 {
      margin-inline:calc(var(--spacing)*2)}

  .mx-auto {
      margin-inline: auto
  }

  .my-10 {
      margin-block:calc(var(--spacing)*10)}

  .my-32 {
      margin-block: calc(var(--spacing)*32)
  }

  .-mt-40 {
      margin-top: calc(var(--spacing)*-50)
  }

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

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

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

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

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

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

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

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

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

  .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-10 {
      margin-bottom: calc(var(--spacing)*10)
  }

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

  .block {
      display: block
  }

  .flex {
      display: flex
  }

  .inline-flex {
      display: inline-flex
  }

  .table {
      display: table
  }

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

  .h-2\/5 {
      height: 100%
  }

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

  .h-full {
      height: 100%
  }

  .min-h-dvh {
      min-height: 100dvh
  }

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

  .w-fit {
      width: fit-content
  }

  .w-full {
      width: 100%
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

  .flex-1 {
      flex: 1
  }

  .border-collapse {
      border-collapse: collapse
  }

  .translate-y-0 {
      --tw-translate-y: calc(var(--spacing)*0);
      translate: var(--tw-translate-x)var(--tw-translate-y)
  }

  .translate-y-8 {
      --tw-translate-y: calc(var(--spacing)*8);
      translate: var(--tw-translate-x)var(--tw-translate-y)
  }

  .translate-y-12 {
      --tw-translate-y: calc(var(--spacing)*12);
      translate: var(--tw-translate-x)var(--tw-translate-y)
  }

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

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

  .flex-col {
      flex-direction: column
  }

  .flex-row-reverse {
      flex-direction: row-reverse
  }

  .items-center {
      align-items: center
  }

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

  .justify-center {
      justify-content: center
  }

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

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

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

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

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

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

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

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

  :where(.space-y-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)))
  }

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

  .overflow-hidden {
      overflow: hidden
  }

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

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

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

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

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

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

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

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

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

  .border-black\/10 {
      border-color: #0000001a
  }

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

  .border-black\/20 {
      border-color: #0003
  }

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

  .border-t-black\/10 {
      border-top-color: #0000001a
  }

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

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

  .bg-black\/5 {
      background-color: #0000000d
  }

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

  .bg-black\/\[3\%\] {
      background-color: #00000008
  }

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

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

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

  .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-white\/95 {
      --tw-gradient-via: #fffffff2
  }

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

  .via-white\/95 {
      --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-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))
  }

  .object-cover {
      object-fit: cover
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  .text-center {
      text-align: center
  }

  .text-left {
      text-align: left
  }

  .align-top {
      vertical-align: top
  }

  .font-\[family-name\: var\(--font-geist-sans\)\] {
      font-family:var(--font-geist-sans)
  }

  .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-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-\[36px\] {
      font-size: 36px
  }

  .leading-\[40px\] {
      --tw-leading: 40px;
      line-height: 40px
  }

  .leading-\[42px\] {
      --tw-leading: 42px;
      line-height: 42px
  }

  .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-bold {
      --tw-font-weight: var(--font-weight-bold);
      font-weight: var(--font-weight-bold)
  }

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

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

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

  .text-\[\#1E1E1E\] {
      color: #1e1e1e
  }

  .text-\[\#6F6F6F\] {
      color: #6f6f6f
  }

  .text-\[rgba\(0\,0\,0\,0\.55\)\] {
      color: #0000008c
  }

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

  .text-black\/45 {
      color: #00000073
  }

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

  .text-black\/55 {
      color: #0000008c
  }

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

  .text-black\/60 {
      color: #0009
  }

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

  .text-black\/70 {
      color: #000000b3
  }

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

  .text-black\/80 {
      color: #000c
  }

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

  .text-blue-600 {
      color: var(--color-blue-600)
  }

  .text-gray-500 {
      color: var(--color-gray-500)
  }

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

  .italic {
      font-style: italic
  }

  .antialiased {
      -webkit-font-smoothing: antialiased;
      -moz-osx-font-smoothing: grayscale
  }

  .opacity-0 {
      opacity: 0
  }

  .opacity-100 {
      opacity: 1
  }

  .backdrop-blur-2xl {
      --tw-backdrop-blur: blur(var(--blur-2xl));
      -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: 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))
  }

  .duration-200 {
      --tw-duration: .2s;
      transition-duration: .2s
  }

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

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

  @media (hover: hover) {
      .hover\:bg-black\/90:hover {
          background-color:#000000e6
      }

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

      .hover\:underline:hover {
          text-decoration-line: underline
      }

      .hover\:opacity-70:hover {
          opacity: .7
      }

      .hover\:opacity-80:hover {
          opacity: .8
      }
  }

  .focus-visible\: opacity-70:focus-visible {
      opacity:.7
  }

  .focus-visible\: opacity-80:focus-visible {
      opacity:.8
  }

  @media not all and (min-width: 64rem) {
      .max-lg\:hidden {
          display:none
      }

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

  @media not all and (min-width: 48rem) {
      .max-md\:flex-col {
          flex-direction:column
      }
  }

  @media not all and (min-width: 40rem) {
      .max-sm\:mt-2 {
          margin-top:calc(var(--spacing)*2)
      }

      .max-sm\:mt-12 {
          margin-top: calc(var(--spacing)*12)
      }

      .max-sm\:hidden {
          display: none
      }

      .max-sm\:flex-col {
          flex-direction: column
      }

      .max-sm\:items-start {
          align-items: flex-start
      }
  }

  @media (min-width: 40rem) {
      .sm\:-mt-48 {
          margin-top:calc(var(--spacing)*-48)
      }

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

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

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

  @media (min-width: 48rem) {
      .md\:max-w-\[360px\] {
          max-width:360px
      }

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

      .md\:gap-7 {
          gap: calc(var(--spacing)*7)
      }

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

      .md\:pt-44 {
          padding-top: calc(var(--spacing)*44)
      }

      .md\:text-\[64px\] {
          font-size: 64px
      }

      .md\:leading-\[26\.1px\] {
          --tw-leading: 26.1px;
          line-height: 26.1px
      }

      .md\:leading-\[26px\] {
          --tw-leading: 26px;
          line-height: 26px
      }

      .md\:leading-\[70\.4px\] {
          --tw-leading: 70.4px;
          line-height: 70.4px
      }

      .md\:leading-\[70px\] {
          --tw-leading: 70px;
          line-height: 70px
      }
  }

  @media (min-width: 64rem) {
      .lg\:mx-0 {
          margin-inline:calc(var(--spacing)*0)
      }

      .lg\:-mt-68 {
          margin-top: calc(var(--spacing)*-68)
      }

      .lg\:w-auto {
          width: auto
      }

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

      .lg\:max-w-\[465px\] {
          max-width: 465px
      }

      .lg\:max-w-\[520px\] {
          max-width: 520px
      }

      .lg\:max-w-\[575px\] {
          max-width: 575px
      }

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

  .\[\&_ol\]\: mt-2 ol {
      margin-top:calc(var(--spacing)*2)
  }

  .\[\&_ol\]\: list-decimal ol {
      list-style-type:decimal
  }

  .\[\&_ol\]\: pl-5 ol {
      padding-left:calc(var(--spacing)*5)
  }

  .\[\&_ul\]\: mt-2 ul {
      margin-top:calc(var(--spacing)*2)
  }

  .\[\&_ul\]\: list-disc ul {
      list-style-type:disc
  }

  .\[\&_ul\]\: pl-5 ul {
      padding-left:calc(var(--spacing)*5)
  }

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

  .\[\&\>ul\>li\]\: leading-relaxed>ul>li {
      --tw-leading:var(--leading-relaxed);
      line-height: var(--leading-relaxed)
  }
}

@keyframes flashing {
  0%,to {
      background-color: #9880ff33
  }

  50% {
      background-color: #9880ff
  }
}

@keyframes accordion-down {
  0% {
      height: 0
  }

  to {
      height: var(--radix-accordion-content-height)
  }
}

@keyframes accordion-up {
  0% {
      height: var(--radix-accordion-content-height)
  }

  to {
      height: 0
  }
}

body {
  font-family: Inter,Inter Fallback,sans-serif
}

.font-opti {
  font-family: Opti Pegasus,serif
}

.font-crimson {
  font-family: Crimson Text,serif
}

.font-geist {
  font-family: Geist,sans-serif
}

.font-geistmono {
  font-family: Geist Mono,monospace
}

.font-inter {
  font-family: Inter,Inter Fallback,sans-serif
}

@font-face {
  font-family: Geist;
  src: url(/fonts/GeistVF.woff)format("woff");
  font-weight: 100 900;
  font-display: swap
}

@font-face {
  font-family: Geist Mono;
  src: url(/fonts/GeistMonoVF.woff)format("woff");
  font-weight: 100 900;
  font-display: swap
}

@font-face {
  font-family: Crimson Text;
  src: url(/fonts/CrimsonText-Regular.ttf)format("truetype");
  font-weight: 400;
  font-display: swap
}

@font-face {
  font-family: Opti Pegasus;
  src: url(/fonts/OPTIPegasus.otf)format("opentype");
  font-weight: 400;
  font-display: swap
}

.podcast-img {
  width: 180px;
  height: 180px;
  transform: translate(-50%,-50%)rotate(var(--rotate));
  top: calc(var(--y,0px) + var(--center-y,0px) - (var(--radius-y,400px)*sin(3.1415*var(--i)/var(--n))));
  left: calc(var(--x,0px) + var(--center-x,0px) + (var(--radius-x,580px)*cos(3.1415*var(--i)/var(--n))))
}

@media (max-width: 640px) {
  .podcast-img {
      --center-x:0px;
      --center-y: 0px;
      --radius-x: 240px;
      --radius-y: 80px;
      width: 150px;
      height: 150px;
      transform: translate(-50%,-50%)rotate(var(--small-rotate));
      top: calc(var(--small-y) + var(--center-y,0px) - (var(--radius-y,400px)*sin(3.1415*var(--i)/var(--n))));
      left: calc(var(--center-x,0px) + (var(--radius-x,580px)*cos(3.1415*var(--i)/var(--n))));
      opacity: var(--opacity,1);
      filter: var(--blur,none)
  }
}

@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-backdrop-blur {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-brightness {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-contrast {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-grayscale {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-invert {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-opacity {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-saturate {
  syntax: "*";
  inherits: false
}

@property --tw-backdrop-sepia {
  syntax: "*";
  inherits: false
}

@property --tw-duration {
  syntax: "*";
  inherits: false
}

@property --tw-ease {
  syntax: "*";
  inherits: false
}

/* Landing nav + footer overrides */
.landing-header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    padding: 1rem clamp(1rem, 4vw, 1.5rem);
    z-index: 100;
}

.landing-nav {
    width: min(1220px, 100%);
    margin: 0 auto;
    padding: 0.75rem 1.5rem;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
}

.landing-nav__group {
    display: inline-flex;
    align-items: center;
    gap: clamp(1.25rem, 3vw, 2rem);
}

.landing-nav__links {
    display: inline-flex;
    align-items: center;
    gap: clamp(1rem, 2.75vw, 1.75rem);
    list-style: none;
    margin: 0;
    padding: 0;
}

.landing-nav__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.35rem 0;
    font-size: 0.95rem;
    font-weight: 500;
    color: rgba(0, 0, 0, 0.68);
    text-decoration: none;
    transition: color 0.2s ease;
}

.landing-nav__link:hover,
.landing-nav__link:focus-visible {
    color: rgba(0, 0, 0, 0.92);
}

.landing-nav__user {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.95rem;
    font-weight: 500;
    color: rgba(0, 0, 0, 0.78);
}

.landing-nav__user-button {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: rgba(255, 255, 255, 0.7);
    color: inherit;
    font-size: inherit;
    cursor: pointer;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.landing-nav__user-button:hover,
.landing-nav__user-button:focus-visible {
    border-color: rgba(0, 0, 0, 0.18);
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.landing-nav__avatar {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    object-fit: cover;
    background: rgba(255, 255, 255, 0.6);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
}

.landing-nav__avatar.fallback {
    color: rgba(0, 0, 0, 0.68);
}

.landing-nav__user-name {
    font-weight: 600;
}

.landing-nav__chevron {
    color: rgba(0, 0, 0, 0.55);
    transition: transform 0.2s ease;
}

.user-dropdown .dropdown-menu {
    position: absolute;
    right: 0;
    top: calc(100% + 0.5rem);
    display: none;
    min-width: 180px;
    border-radius: 16px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 18px 32px rgba(15, 23, 42, 0.12);
    padding: 0.75rem;
    z-index: 30;
}

.user-dropdown .dropdown-menu.show {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.landing-nav__menu-item {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    border-radius: 12px;
    color: rgba(15, 23, 42, 0.75);
    font-weight: 500;
    text-decoration: none;
    transition: background-color 0.2s ease, color 0.2s ease;
}

.landing-nav__menu-item:hover,
.landing-nav__menu-item:focus-visible {
    background: rgba(15, 23, 42, 0.08);
    color: rgba(15, 23, 42, 0.92);
}

.landing-nav__menu-item--danger {
    color: #dc2626;
}

.landing-nav__menu-item--danger:hover,
.landing-nav__menu-item--danger:focus-visible {
    background: rgba(220, 38, 38, 0.08);
    color: #b91c1c;
}

.user-dropdown .user-button.is-open .landing-nav__chevron {
    transform: rotate(180deg);
}

.landing-nav__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.65rem 1.5rem;
    border-radius: 999px;
    font-weight: 600;
    font-size: 0.95rem;
    color: #ffffff;
    background: #111827;
    box-shadow: 0 12px 24px rgba(17, 24, 39, 0.16);
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.landing-nav__cta:hover,
.landing-nav__cta:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 18px 32px rgba(17, 24, 39, 0.22);
}

.reference-nav-logo {
    flex-shrink: 0;
    line-height: 0;
    padding-left: 16px;
}

.reference-nav-logo .brand {
    flex: none;
    width: clamp(160px, 28vw, 220px);
    height: auto;
}

.reference-nav-logo .brand--mobile {
    display: none;
    width: 56px;
}

/* .reference-footer {
    margin-top: calc(var(--spacing)*24);
} */

.reference-footer-inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: calc(var(--spacing)*8);
    width: 100%;
    max-width: 1220px;
    margin-inline: auto;
    padding: calc(var(--spacing)*10) calc(var(--spacing)*6);
}

.reference-footer-copy {
    color: #4c4c4c;
    display: inline-flex;
    align-items: center;
    position: relative;
    padding-bottom: calc(var(--spacing)*2.5);
    font-size: 0.95rem;
}

.reference-footer-copy::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 60px;
    height: 1px;
    background: currentColor;
    opacity: 0.35;
}

.reference-footer-actions {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    gap: calc(var(--spacing)*6);
    flex-wrap: wrap;
}

.reference-footer-contact {
    display: inline-flex;
    align-items: center;
    gap: calc(var(--spacing)*3);
    font-weight: var(--font-weight-medium);
    color: inherit;
    text-decoration: none;
    position: relative;
    padding-bottom: calc(var(--spacing)*2.5);
}

.reference-footer-contact::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 48px;
    height: 1px;
    background: currentColor;
    opacity: 0.35;
    transition: opacity 0.2s ease;
}

.reference-footer-contact:hover::after,
.reference-footer-contact:focus-visible::after {
    opacity: 0.6;
}

.reference-footer-contact-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    margin-right: calc(var(--spacing)*3);
}

.reference-footer-social {
    display: inline-flex;
    align-items: center;
    gap: calc(var(--spacing)*4);
}

.reference-footer-social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    background: rgba(0, 0, 0, 0.06);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.reference-footer-social-link:hover,
.reference-footer-social-link:focus-visible {
    opacity: 0.7;
    transform: translateY(-1px);
}

@media (min-width: 48rem) {
    .reference-footer-inner {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        padding: calc(var(--spacing)*8) calc(var(--spacing)*6);
    }

    .reference-footer-actions {
        width: auto;
        justify-content: flex-end;
        gap: calc(var(--spacing)*8);
    }

    .reference-footer-copy {
        padding-bottom: calc(var(--spacing)*2);
    }
}

@media (max-width: 48rem) {
    .reference-footer-actions {
        order: 1;
    }

    .reference-footer-copy {
        order: 2;
    }
}

@media (max-width: 48rem) {
    .landing-nav__group {
        gap: 1rem;
    }

    .landing-nav__links {
        gap: 0.75rem;
    }

    .landing-nav__cta {
        padding: 0.6rem 1.25rem;
        font-size: 1rem;
    }

    .reference-nav-logo {
        padding-left: 0.75rem;
    }

    .reference-nav-logo .brand--desktop {
        width: clamp(140px, 36vw, 184px);
    }
}

@media (max-width: 32rem) {
    .landing-nav__group {
        gap: 0.75rem;
    }

    .landing-nav__links {
        gap: 0.6rem;
    }

    .landing-nav__link {
        font-size: 0.9rem;
    }

    .reference-nav-logo {
        padding-left: 0.5rem;
    }

    .reference-nav-logo .brand--desktop {
        display: none;
    }

    .reference-nav-logo .brand--mobile {
        display: block;
    }

    .landing-hero {
        --landing-cta-offset: -6rem;
    }
}

@media (max-width: 26rem) {
    .reference-nav-logo {
        padding-left: 0.35rem;
    }

    .reference-nav-logo .brand--mobile {
        width: 48px;
    }

    .landing-nav__group {
        gap: 0.65rem;
    }

    .landing-nav__user-button {
        padding: 0.3rem 0.6rem;
    }
}

@media (max-width: 40rem) {
    .landing-hero__headline {
        min-height: clamp(9rem, 24vw, 12rem);
    }

    .landing-hero__title {
        font-size: clamp(2rem, 8vw, 2.6rem);
    }

    .landing-hero__visual {
        margin: clamp(1.75rem, 8vw, 2.75rem) auto 0;
    }
}

.reference-word-rotator {
    display: inline-block;
    position: relative;
    overflow: hidden;
    vertical-align: baseline;
    line-height: 1;
    min-height: 1em;
    padding-bottom: 0.2em;
    margin-bottom: -0.2em;
}

.reference-word {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    display: block;
    font-style: italic;
    transform-origin: 50% 50%;
    backface-visibility: hidden;
    white-space: nowrap;
    opacity: 0;
}

.reference-word--show {
    font-style: italic;
    opacity: 1;
}

.reference-word--enter {
    animation: referenceWordEnter 0.55s forwards cubic-bezier(0.33, 1, 0.68, 1);
}

.reference-word--shimmer::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0.4) 45%, rgba(255,255,255,0) 95%);
    transform: translateX(-120%);
    animation: referenceWordShimmer 0.6s forwards ease;
}

.reference-word--shimmer {
    position: relative;
    background: linear-gradient(120deg, #f64a6b, #ff7a26, #2e7c57, #3546e6, #7d38e6);
    -webkit-background-clip: text;
    color: transparent;
}

.reference-word--exit {
    animation: referenceWordExit 0.45s forwards cubic-bezier(0.65, 0, 0.35, 1);
}

@keyframes referenceWordEnter {
    0% {
        transform: translateY(110%) scale(0.98);
        opacity: 0;
    }

    100% {
        transform: translateY(0) scale(1);
        opacity: 1;
    }
}

@keyframes referenceWordExit {
    0% {
        transform: translateY(0) scale(1);
        opacity: 1;
    }

    100% {
        transform: translateY(-110%) scale(0.98);
        opacity: 0;
    }
}

@keyframes referenceWordShimmer {
    0% {
        transform: translateX(-120%);
        opacity: 0;
    }

    20% {
        opacity: 1;
    }

    100% {
        transform: translateX(120%);
        opacity: 0;
    }
}

@media (max-width: 40rem) {
    .reference-hero {
        padding-top: calc(var(--spacing)*25);
    }

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

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

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

.reference-footer-meta .xs-sans {
    font-size: 0.75rem;
    line-height: 1.35;
}
}

/* Landing hero layout */
.landing-hero {
    --landing-cta-offset: clamp(-20rem, -26vw, -8rem);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: clamp(1rem, 3vw, 1.75rem);
    min-height: auto;
    padding-top: clamp(7rem, 11vw, 9.5rem);
    padding-bottom: clamp(5rem, 10vw, 7rem);
    text-align: center;
    color: #1e1e1e;
}

.landing-hero__headline {
    min-height: clamp(6.5rem, 9vw, 10rem);
    margin-top: clamp(1rem, 2.5vw, 1.75rem);
}

.landing-hero__title {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(0.25rem, 1.5vw, 0.6rem);
    font-size: clamp(2.25rem, 7vw, 3.25rem);
    line-height: 1.1;
    margin: 0;
}

.landing-hero__title-line {
    display: block;
    font-weight: inherit;
}

.landing-hero__title-line--lead {
    text-wrap: balance;
}

.landing-hero__title-line--subject {
    white-space: nowrap;
}

.landing-hero__title-rotator {
    display: block;
    min-height: 1em;
}

@media (min-width: 60rem) {
    .landing-hero__title {
        display: block;
    }

    .landing-hero__title-line {
        display: inline;
    }

    .landing-hero__title-line--lead {
        margin-right: 0.35rem;
    }

    .landing-hero__title-rotator {
        margin-top: clamp(0.45rem, 1.2vw, 0.8rem);
    }
}

.landing-hero__visual {
    position: relative;
    width: clamp(520px, 60vw, 960px);
    max-width: none;
    margin-top: clamp(0.9rem, 2.4vw, 1.9rem);
}

.landing-hero__visual img,
.landing-hero__image {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
}

.landing-hero__visual-gradient {
    position: absolute;
    inset: auto 0 0;
    height: 75%;
    background: linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.96) 60%, rgba(255, 255, 255, 0.82) 70%, rgba(255, 255, 255, 0.58) 78%, rgba(255, 255, 255, 0) 100%);
    pointer-events: none;
    z-index: 1;
}

.landing-hero__cta {
    position: relative;
    z-index: 2;
    margin-top: var(--landing-cta-offset);
    margin-bottom: clamp(2.8rem, 6vw, 3.5rem);
    width: min(360px, 70%);
    font-size: 1.08rem;
    padding: 1.2rem 1.5rem;
    border-radius: 999px;
    background: #111827;
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    box-shadow: 0 18px 38px rgba(17, 24, 39, 0.22);
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.landing-hero__cta:hover,
.landing-hero__cta:focus-visible {
    transform: translateY(-2px);
    opacity: 0.92;
    box-shadow: 0 24px 48px rgba(17, 24, 39, 0.28);
}

@media (max-width: 48rem) {
    .landing-hero {
        padding: clamp(6rem, 20vw, 7.75rem) clamp(1rem, 6vw, 1.75rem) clamp(4.5rem, 14vw, 6.5rem);
        gap: clamp(1rem, 6vw, 1.6rem);
    }

    .landing-hero {
        --landing-cta-offset: clamp(-25rem, -70vw, -7.2rem);
    }

    .landing-hero__headline {
        min-height: auto;
    }

    .landing-hero__visual {
        width: clamp(500px, 178vw, 720px);
        margin-top: clamp(0.45rem, 5vw, 1.1rem);
        margin-left: calc(-0.5 * (clamp(500px, 178vw, 720px) - 100%));
        margin-right: calc(-0.5 * (clamp(500px, 178vw, 720px) - 100%));
    }
}

@media (min-width: 48rem) and (max-width: 72rem) {
    .landing-hero {
        padding-top: clamp(6.25rem, 9vw, 7.5rem);
        padding-bottom: clamp(5rem, 9vw, 6.5rem);
        gap: clamp(1.1rem, 3vw, 1.6rem);
    }

    .landing-hero {
        --landing-cta-offset: clamp(-25rem, -26vw, -7.8rem);
    }

    .landing-hero__visual {
        width: clamp(540px, 64vw, 860px);
        margin-top: clamp(0.8rem, 2.2vw, 1.65rem);
    }
}

@media (min-width: 72rem) {
    .landing-hero {
        padding-top: clamp(6.5rem, 8vw, 8rem);
        padding-bottom: clamp(5.5rem, 8vw, 7rem);
    }

    .landing-hero {
        --landing-cta-offset: clamp(-30rem, -25vw, -8.5rem);
    }

    .landing-hero__visual {
        width: clamp(620px, 52vw, 980px);
        margin-top: clamp(0.75rem, 2vw, 1.6rem);
    }
}
