/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@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-teal-200: oklch(91% 0.096 180.426);
    --color-teal-400: oklch(77.7% 0.152 181.912);
    --color-gray-100: oklch(96.7% 0.003 264.542);
    --color-gray-200: oklch(92.8% 0.006 264.531);
    --color-gray-400: oklch(70.7% 0.022 261.325);
    --color-gray-600: oklch(44.6% 0.03 256.802);
    --color-black: #000;
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-xl: 36rem;
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --radius-2xl: 1rem;
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-primary: #163F8F;
    --color-secondary: #02ADB1;
    --color-tertiary: #D3EBEC;
    --color-dark: #212529;
    --color-description: #3A3A3A;
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    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 {
    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;
  }
  :-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 {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :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)) {
        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, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .pointer-events-none {
    pointer-events: none;
  }
  .visible {
    visibility: visible;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }
  .-top-\[24px\] {
    top: calc(24px * -1);
  }
  .-top-\[26px\] {
    top: calc(26px * -1);
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .top-1\/2 {
    top: calc(1 / 2 * 100%);
  }
  .top-\[54px\] {
    top: 54px;
  }
  .top-\[390px\] {
    top: 390px;
  }
  .top-\[500px\] {
    top: 500px;
  }
  .right-0 {
    right: calc(var(--spacing) * 0);
  }
  .right-\[25px\] {
    right: 25px;
  }
  .bottom-0 {
    bottom: calc(var(--spacing) * 0);
  }
  .bottom-2 {
    bottom: calc(var(--spacing) * 2);
  }
  .bottom-\[20px\] {
    bottom: 20px;
  }
  .left-0 {
    left: calc(var(--spacing) * 0);
  }
  .left-1\/2 {
    left: calc(1 / 2 * 100%);
  }
  .z-0 {
    z-index: 0;
  }
  .z-10 {
    z-index: 10;
  }
  .z-\[-3\] {
    z-index: -3;
  }
  .z-\[0\] {
    z-index: 0;
  }
  .z-\[1\] {
    z-index: 1;
  }
  .z-\[2\] {
    z-index: 2;
  }
  .z-\[3\] {
    z-index: 3;
  }
  .z-\[98\] {
    z-index: 98;
  }
  .z-\[99\] {
    z-index: 99;
  }
  .z-\[101\] {
    z-index: 101;
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .mx-auto {
    margin-inline: auto;
  }
  .-mt-4 {
    margin-top: calc(var(--spacing) * -4);
  }
  .-mt-\[19px\] {
    margin-top: calc(19px * -1);
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .mt-10 {
    margin-top: calc(var(--spacing) * 10);
  }
  .mt-\[8px\] {
    margin-top: 8px;
  }
  .mt-\[12px\] {
    margin-top: 12px;
  }
  .mt-\[24px\] {
    margin-top: 24px;
  }
  .mt-auto {
    margin-top: auto;
  }
  .mr-1 {
    margin-right: calc(var(--spacing) * 1);
  }
  .mr-\[14px\] {
    margin-right: 14px;
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }
  .mb-12 {
    margin-bottom: calc(var(--spacing) * 12);
  }
  .mb-\[4px\] {
    margin-bottom: 4px;
  }
  .mb-\[8px\] {
    margin-bottom: 8px;
  }
  .mb-\[10px\] {
    margin-bottom: 10px;
  }
  .mb-\[12px\] {
    margin-bottom: 12px;
  }
  .mb-\[15px\] {
    margin-bottom: 15px;
  }
  .mb-\[16px\] {
    margin-bottom: 16px;
  }
  .mb-\[20px\] {
    margin-bottom: 20px;
  }
  .mb-\[24px\] {
    margin-bottom: 24px;
  }
  .mb-\[30px\] {
    margin-bottom: 30px;
  }
  .mb-\[33px\] {
    margin-bottom: 33px;
  }
  .mb-\[40px\] {
    margin-bottom: 40px;
  }
  .mb-\[60px\] {
    margin-bottom: 60px;
  }
  .-ml-\[100px\] {
    margin-left: calc(100px * -1);
  }
  .-ml-\[120px\] {
    margin-left: calc(120px * -1);
  }
  .-ml-\[130px\] {
    margin-left: calc(130px * -1);
  }
  .line-clamp-2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  .line-clamp-3 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
  }
  .block {
    display: block;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .h-2 {
    height: calc(var(--spacing) * 2);
  }
  .h-4 {
    height: calc(var(--spacing) * 4);
  }
  .h-5 {
    height: calc(var(--spacing) * 5);
  }
  .h-\[2px\] {
    height: 2px;
  }
  .h-\[3px\] {
    height: 3px;
  }
  .h-\[16px\] {
    height: 16px;
  }
  .h-\[20px\] {
    height: 20px;
  }
  .h-\[44px\] {
    height: 44px;
  }
  .h-\[54px\] {
    height: 54px;
  }
  .h-\[60px\] {
    height: 60px;
  }
  .h-\[70px\] {
    height: 70px;
  }
  .h-\[100px\] {
    height: 100px;
  }
  .h-\[130px\] {
    height: 130px;
  }
  .h-\[175px\] {
    height: 175px;
  }
  .h-\[200px\] {
    height: 200px;
  }
  .h-\[250px\] {
    height: 250px;
  }
  .h-\[370px\] {
    height: 370px;
  }
  .h-\[426px\] {
    height: 426px;
  }
  .h-\[650px\] {
    height: 650px;
  }
  .h-\[750px\] {
    height: 750px;
  }
  .h-\[1083px\] {
    height: 1083px;
  }
  .h-auto {
    height: auto;
  }
  .h-full {
    height: 100%;
  }
  .max-h-0 {
    max-height: calc(var(--spacing) * 0);
  }
  .max-h-\[264px\] {
    max-height: 264px;
  }
  .max-h-\[370px\] {
    max-height: 370px;
  }
  .min-h-\[175px\] {
    min-height: 175px;
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .\!w-\[256px\] {
    width: 256px !important;
  }
  .w-2 {
    width: calc(var(--spacing) * 2);
  }
  .w-4 {
    width: calc(var(--spacing) * 4);
  }
  .w-5 {
    width: calc(var(--spacing) * 5);
  }
  .w-6 {
    width: calc(var(--spacing) * 6);
  }
  .w-\[9px\] {
    width: 9px;
  }
  .w-\[16px\] {
    width: 16px;
  }
  .w-\[24px\] {
    width: 24px;
  }
  .w-\[30px\] {
    width: 30px;
  }
  .w-\[40\%\] {
    width: 40%;
  }
  .w-\[44px\] {
    width: 44px;
  }
  .w-\[60px\] {
    width: 60px;
  }
  .w-\[80px\] {
    width: 80px;
  }
  .w-\[112px\] {
    width: 112px;
  }
  .w-\[114px\] {
    width: 114px;
  }
  .w-\[180px\] {
    width: 180px;
  }
  .w-\[253px\] {
    width: 253px;
  }
  .w-\[350px\] {
    width: 350px;
  }
  .w-\[450px\] {
    width: 450px;
  }
  .w-\[600px\] {
    width: 600px;
  }
  .w-\[870px\] {
    width: 870px;
  }
  .w-full {
    width: 100%;
  }
  .max-w-\[430px\] {
    max-width: 430px;
  }
  .max-w-\[600px\] {
    max-width: 600px;
  }
  .max-w-\[773px\] {
    max-width: 773px;
  }
  .max-w-xl {
    max-width: var(--container-xl);
  }
  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }
  .flex-1 {
    flex: 1;
  }
  .flex-shrink {
    flex-shrink: 1;
  }
  .flex-shrink-0 {
    flex-shrink: 0;
  }
  .origin-center {
    transform-origin: center;
  }
  .-translate-x-1\/2 {
    --tw-translate-x: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .-translate-y-1\/2 {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-y-3 {
    --tw-translate-y: calc(var(--spacing) * 3);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .cursor-not-allowed {
    cursor: not-allowed;
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .resize {
    resize: both;
  }
  .scroll-pt-\[20px\] {
    scroll-padding-top: 20px;
  }
  .scroll-pb-\[20px\] {
    scroll-padding-bottom: 20px;
  }
  .appearance-none {
    appearance: none;
  }
  .grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .flex-col {
    flex-direction: column;
  }
  .flex-row {
    flex-direction: row;
  }
  .items-center {
    align-items: center;
  }
  .items-end {
    align-items: flex-end;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-\[5px\] {
    gap: 5px;
  }
  .gap-\[6px\] {
    gap: 6px;
  }
  .gap-\[7px\] {
    gap: 7px;
  }
  .gap-\[8px\] {
    gap: 8px;
  }
  .gap-\[10px\] {
    gap: 10px;
  }
  .gap-\[12px\] {
    gap: 12px;
  }
  .gap-\[14px\] {
    gap: 14px;
  }
  .gap-\[16px\] {
    gap: 16px;
  }
  .gap-\[20px\] {
    gap: 20px;
  }
  .gap-\[30px\] {
    gap: 30px;
  }
  .gap-\[52px\] {
    gap: 52px;
  }
  .truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .rounded-\[10px\] {
    border-radius: 10px;
  }
  .rounded-\[16px\] {
    border-radius: 16px;
  }
  .rounded-\[20px\] {
    border-radius: 20px;
  }
  .rounded-full {
    border-radius: calc(infinity * 1px);
  }
  .rounded-t-\[16px\] {
    border-top-left-radius: 16px;
    border-top-right-radius: 16px;
  }
  .rounded-l-2xl {
    border-top-left-radius: var(--radius-2xl);
    border-bottom-left-radius: var(--radius-2xl);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-0 {
    border-style: var(--tw-border-style);
    border-width: 0px;
  }
  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
  .border-none {
    --tw-border-style: none;
    border-style: none;
  }
  .border-gray-100 {
    border-color: var(--color-gray-100);
  }
  .border-gray-200 {
    border-color: var(--color-gray-200);
  }
  .border-secondary {
    border-color: var(--color-secondary);
  }
  .bg-\[\#F0F7FA\] {
    background-color: #F0F7FA;
  }
  .bg-black\/90 {
    background-color: color-mix(in srgb, #000 90%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 90%, transparent);
    }
  }
  .bg-primary {
    background-color: var(--color-primary);
  }
  .bg-tertiary {
    background-color: var(--color-tertiary);
  }
  .bg-transparent {
    background-color: transparent;
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .bg-cover {
    background-size: cover;
  }
  .bg-center {
    background-position: center;
  }
  .object-contain {
    object-fit: contain;
  }
  .object-cover {
    object-fit: cover;
  }
  .p-\[4px\] {
    padding: 4px;
  }
  .p-\[16px\] {
    padding: 16px;
  }
  .p-\[22px\] {
    padding: 22px;
  }
  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }
  .px-\[12px\] {
    padding-inline: 12px;
  }
  .px-\[20px\] {
    padding-inline: 20px;
  }
  .px-\[24px\] {
    padding-inline: 24px;
  }
  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }
  .py-20 {
    padding-block: calc(var(--spacing) * 20);
  }
  .py-\[8px\] {
    padding-block: 8px;
  }
  .py-\[12px\] {
    padding-block: 12px;
  }
  .py-\[14px\] {
    padding-block: 14px;
  }
  .py-\[17px\] {
    padding-block: 17px;
  }
  .py-\[20px\] {
    padding-block: 20px;
  }
  .py-\[100px\] {
    padding-block: 100px;
  }
  .pt-14 {
    padding-top: calc(var(--spacing) * 14);
  }
  .pt-\[26px\] {
    padding-top: 26px;
  }
  .pt-\[32px\] {
    padding-top: 32px;
  }
  .pt-\[34px\] {
    padding-top: 34px;
  }
  .pt-\[40px\] {
    padding-top: 40px;
  }
  .pt-\[60px\] {
    padding-top: 60px;
  }
  .pr-\[11px\] {
    padding-right: 11px;
  }
  .pr-\[26px\] {
    padding-right: 26px;
  }
  .pr-\[50px\] {
    padding-right: 50px;
  }
  .pb-12 {
    padding-bottom: calc(var(--spacing) * 12);
  }
  .pb-\[16px\] {
    padding-bottom: 16px;
  }
  .pb-\[28px\] {
    padding-bottom: 28px;
  }
  .pb-\[40px\] {
    padding-bottom: 40px;
  }
  .pb-\[50px\] {
    padding-bottom: 50px;
  }
  .pb-\[76px\] {
    padding-bottom: 76px;
  }
  .pb-\[80px\] {
    padding-bottom: 80px;
  }
  .pb-\[100px\] {
    padding-bottom: 100px;
  }
  .pl-\[17px\] {
    padding-left: 17px;
  }
  .text-center {
    text-align: center;
  }
  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .text-\[12px\] {
    font-size: 12px;
  }
  .text-\[14px\] {
    font-size: 14px;
  }
  .text-\[16px\] {
    font-size: 16px;
  }
  .text-\[20px\] {
    font-size: 20px;
  }
  .text-\[22px\] {
    font-size: 22px;
  }
  .text-\[28px\] {
    font-size: 28px;
  }
  .leading-\[18px\] {
    --tw-leading: 18px;
    line-height: 18px;
  }
  .leading-\[20px\] {
    --tw-leading: 20px;
    line-height: 20px;
  }
  .leading-\[24px\] {
    --tw-leading: 24px;
    line-height: 24px;
  }
  .leading-\[26px\] {
    --tw-leading: 26px;
    line-height: 26px;
  }
  .leading-\[28px\] {
    --tw-leading: 28px;
    line-height: 28px;
  }
  .leading-\[30px\] {
    --tw-leading: 30px;
    line-height: 30px;
  }
  .leading-\[38px\] {
    --tw-leading: 38px;
    line-height: 38px;
  }
  .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);
  }
  .text-\[\#D1D5DB\] {
    color: #D1D5DB;
  }
  .text-description {
    color: var(--color-description);
  }
  .text-gray-400 {
    color: var(--color-gray-400);
  }
  .text-gray-600 {
    color: var(--color-gray-600);
  }
  .text-primary {
    color: var(--color-primary);
  }
  .text-secondary {
    color: var(--color-secondary);
  }
  .text-teal-200 {
    color: var(--color-teal-200);
  }
  .text-teal-400 {
    color: var(--color-teal-400);
  }
  .text-white {
    color: var(--color-white);
  }
  .uppercase {
    text-transform: uppercase;
  }
  .placeholder-dark {
    &::placeholder {
      color: var(--color-dark);
    }
  }
  .opacity-0 {
    opacity: 0%;
  }
  .opacity-100 {
    opacity: 100%;
  }
  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[0px_0px_10px_0px_\#00000026\] {
    --tw-shadow: 0px 0px 10px 0px var(--tw-shadow-color, #00000026);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-md {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .ring {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .duration-300 {
    --tw-duration: 300ms;
    transition-duration: 300ms;
  }
  .duration-500 {
    --tw-duration: 500ms;
    transition-duration: 500ms;
  }
  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }
  .outline-none {
    --tw-outline-style: none;
    outline-style: none;
  }
  .group-hover\:bg-transparent {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        background-color: transparent;
      }
    }
  }
  .group-hover\:\!text-white {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: var(--color-white) !important;
      }
    }
  }
  .group-hover\:text-black {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: var(--color-black);
      }
    }
  }
  .group-hover\:text-white {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: var(--color-white);
      }
    }
  }
  .group-hover\:text-white\/80 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: color-mix(in srgb, #fff 80%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-white) 80%, transparent);
        }
      }
    }
  }
  .group-hover\:opacity-0 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        opacity: 0%;
      }
    }
  }
  .group-hover\:opacity-100 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        opacity: 100%;
      }
    }
  }
  .hover\:text-primary {
    &:hover {
      @media (hover: hover) {
        color: var(--color-primary);
      }
    }
  }
  .hover\:opacity-50 {
    &:hover {
      @media (hover: hover) {
        opacity: 50%;
      }
    }
  }
  .hover\:opacity-90 {
    &:hover {
      @media (hover: hover) {
        opacity: 90%;
      }
    }
  }
  .max-sm\:h-\[553px\] {
    @media (width < 40rem) {
      height: 553px;
    }
  }
  .min-\[1440px\]\:block {
    @media (width >= 1440px) {
      display: block;
    }
  }
  .md\:absolute {
    @media (width >= 48rem) {
      position: absolute;
    }
  }
  .md\:inset-0 {
    @media (width >= 48rem) {
      inset: calc(var(--spacing) * 0);
    }
  }
  .md\:top-\[97px\] {
    @media (width >= 48rem) {
      top: 97px;
    }
  }
  .md\:-right-\[100px\] {
    @media (width >= 48rem) {
      right: calc(100px * -1);
    }
  }
  .md\:bottom-8 {
    @media (width >= 48rem) {
      bottom: calc(var(--spacing) * 8);
    }
  }
  .md\:-mt-\[24px\] {
    @media (width >= 48rem) {
      margin-top: calc(24px * -1);
    }
  }
  .md\:mt-0 {
    @media (width >= 48rem) {
      margin-top: calc(var(--spacing) * 0);
    }
  }
  .md\:mr-\[20px\] {
    @media (width >= 48rem) {
      margin-right: 20px;
    }
  }
  .md\:mb-\[8px\] {
    @media (width >= 48rem) {
      margin-bottom: 8px;
    }
  }
  .md\:mb-\[10px\] {
    @media (width >= 48rem) {
      margin-bottom: 10px;
    }
  }
  .md\:mb-\[12px\] {
    @media (width >= 48rem) {
      margin-bottom: 12px;
    }
  }
  .md\:mb-\[16px\] {
    @media (width >= 48rem) {
      margin-bottom: 16px;
    }
  }
  .md\:mb-\[18px\] {
    @media (width >= 48rem) {
      margin-bottom: 18px;
    }
  }
  .md\:mb-\[20px\] {
    @media (width >= 48rem) {
      margin-bottom: 20px;
    }
  }
  .md\:mb-\[28px\] {
    @media (width >= 48rem) {
      margin-bottom: 28px;
    }
  }
  .md\:mb-\[36px\] {
    @media (width >= 48rem) {
      margin-bottom: 36px;
    }
  }
  .md\:mb-\[50px\] {
    @media (width >= 48rem) {
      margin-bottom: 50px;
    }
  }
  .md\:mb-\[60px\] {
    @media (width >= 48rem) {
      margin-bottom: 60px;
    }
  }
  .md\:mb-\[100px\] {
    @media (width >= 48rem) {
      margin-bottom: 100px;
    }
  }
  .md\:-ml-\[50px\] {
    @media (width >= 48rem) {
      margin-left: calc(50px * -1);
    }
  }
  .md\:block {
    @media (width >= 48rem) {
      display: block;
    }
  }
  .md\:flex {
    @media (width >= 48rem) {
      display: flex;
    }
  }
  .md\:h-\[4px\] {
    @media (width >= 48rem) {
      height: 4px;
    }
  }
  .md\:h-\[20px\] {
    @media (width >= 48rem) {
      height: 20px;
    }
  }
  .md\:h-\[30px\] {
    @media (width >= 48rem) {
      height: 30px;
    }
  }
  .md\:h-\[97px\] {
    @media (width >= 48rem) {
      height: 97px;
    }
  }
  .md\:h-\[114px\] {
    @media (width >= 48rem) {
      height: 114px;
    }
  }
  .md\:h-\[200px\] {
    @media (width >= 48rem) {
      height: 200px;
    }
  }
  .md\:h-\[220px\] {
    @media (width >= 48rem) {
      height: 220px;
    }
  }
  .md\:h-\[240px\] {
    @media (width >= 48rem) {
      height: 240px;
    }
  }
  .md\:h-\[264px\] {
    @media (width >= 48rem) {
      height: 264px;
    }
  }
  .md\:h-\[300px\] {
    @media (width >= 48rem) {
      height: 300px;
    }
  }
  .md\:h-auto {
    @media (width >= 48rem) {
      height: auto;
    }
  }
  .md\:h-full {
    @media (width >= 48rem) {
      height: 100%;
    }
  }
  .md\:h-screen {
    @media (width >= 48rem) {
      height: 100vh;
    }
  }
  .md\:max-h-\[625px\] {
    @media (width >= 48rem) {
      max-height: 625px;
    }
  }
  .md\:\!w-\[380px\] {
    @media (width >= 48rem) {
      width: 380px !important;
    }
  }
  .md\:w-1\/2 {
    @media (width >= 48rem) {
      width: calc(1 / 2 * 100%);
    }
  }
  .md\:w-\[14px\] {
    @media (width >= 48rem) {
      width: 14px;
    }
  }
  .md\:w-\[20px\] {
    @media (width >= 48rem) {
      width: 20px;
    }
  }
  .md\:w-\[32px\] {
    @media (width >= 48rem) {
      width: 32px;
    }
  }
  .md\:w-\[80px\] {
    @media (width >= 48rem) {
      width: 80px;
    }
  }
  .md\:w-\[129px\] {
    @media (width >= 48rem) {
      width: 129px;
    }
  }
  .md\:w-\[187px\] {
    @media (width >= 48rem) {
      width: 187px;
    }
  }
  .md\:w-\[220px\] {
    @media (width >= 48rem) {
      width: 220px;
    }
  }
  .md\:w-\[280px\] {
    @media (width >= 48rem) {
      width: 280px;
    }
  }
  .md\:w-\[300px\] {
    @media (width >= 48rem) {
      width: 300px;
    }
  }
  .md\:w-\[528px\] {
    @media (width >= 48rem) {
      width: 528px;
    }
  }
  .md\:w-\[650px\] {
    @media (width >= 48rem) {
      width: 650px;
    }
  }
  .md\:w-fit {
    @media (width >= 48rem) {
      width: fit-content;
    }
  }
  .md\:w-full {
    @media (width >= 48rem) {
      width: 100%;
    }
  }
  .md\:max-w-\[1000px\] {
    @media (width >= 48rem) {
      max-width: 1000px;
    }
  }
  .md\:grid-cols-4 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .md\:flex-col {
    @media (width >= 48rem) {
      flex-direction: column;
    }
  }
  .md\:flex-row {
    @media (width >= 48rem) {
      flex-direction: row;
    }
  }
  .md\:items-end {
    @media (width >= 48rem) {
      align-items: flex-end;
    }
  }
  .md\:items-start {
    @media (width >= 48rem) {
      align-items: flex-start;
    }
  }
  .md\:items-stretch {
    @media (width >= 48rem) {
      align-items: stretch;
    }
  }
  .md\:justify-between {
    @media (width >= 48rem) {
      justify-content: space-between;
    }
  }
  .md\:gap-\[12px\] {
    @media (width >= 48rem) {
      gap: 12px;
    }
  }
  .md\:gap-\[14px\] {
    @media (width >= 48rem) {
      gap: 14px;
    }
  }
  .md\:gap-\[30px\] {
    @media (width >= 48rem) {
      gap: 30px;
    }
  }
  .md\:gap-\[36px\] {
    @media (width >= 48rem) {
      gap: 36px;
    }
  }
  .md\:gap-\[50px\] {
    @media (width >= 48rem) {
      gap: 50px;
    }
  }
  .md\:gap-\[52px\] {
    @media (width >= 48rem) {
      gap: 52px;
    }
  }
  .md\:gap-\[60px\] {
    @media (width >= 48rem) {
      gap: 60px;
    }
  }
  .md\:rounded-\[20px\] {
    @media (width >= 48rem) {
      border-radius: 20px;
    }
  }
  .md\:rounded-full {
    @media (width >= 48rem) {
      border-radius: calc(infinity * 1px);
    }
  }
  .md\:rounded-t-\[20px\] {
    @media (width >= 48rem) {
      border-top-left-radius: 20px;
      border-top-right-radius: 20px;
    }
  }
  .md\:object-cover {
    @media (width >= 48rem) {
      object-fit: cover;
    }
  }
  .md\:p-\[26px\] {
    @media (width >= 48rem) {
      padding: 26px;
    }
  }
  .md\:px-\[25px\] {
    @media (width >= 48rem) {
      padding-inline: 25px;
    }
  }
  .md\:px-\[30px\] {
    @media (width >= 48rem) {
      padding-inline: 30px;
    }
  }
  .md\:px-\[36px\] {
    @media (width >= 48rem) {
      padding-inline: 36px;
    }
  }
  .md\:py-\[12px\] {
    @media (width >= 48rem) {
      padding-block: 12px;
    }
  }
  .md\:py-\[25px\] {
    @media (width >= 48rem) {
      padding-block: 25px;
    }
  }
  .md\:py-\[28px\] {
    @media (width >= 48rem) {
      padding-block: 28px;
    }
  }
  .md\:py-\[30px\] {
    @media (width >= 48rem) {
      padding-block: 30px;
    }
  }
  .md\:py-\[100px\] {
    @media (width >= 48rem) {
      padding-block: 100px;
    }
  }
  .md\:pt-\[18px\] {
    @media (width >= 48rem) {
      padding-top: 18px;
    }
  }
  .md\:pt-\[30px\] {
    @media (width >= 48rem) {
      padding-top: 30px;
    }
  }
  .md\:pt-\[50px\] {
    @media (width >= 48rem) {
      padding-top: 50px;
    }
  }
  .md\:pt-\[60px\] {
    @media (width >= 48rem) {
      padding-top: 60px;
    }
  }
  .md\:pt-\[81px\] {
    @media (width >= 48rem) {
      padding-top: 81px;
    }
  }
  .md\:pr-\[25px\] {
    @media (width >= 48rem) {
      padding-right: 25px;
    }
  }
  .md\:pr-\[55px\] {
    @media (width >= 48rem) {
      padding-right: 55px;
    }
  }
  .md\:pr-\[68px\] {
    @media (width >= 48rem) {
      padding-right: 68px;
    }
  }
  .md\:pb-\[30px\] {
    @media (width >= 48rem) {
      padding-bottom: 30px;
    }
  }
  .md\:pb-\[32px\] {
    @media (width >= 48rem) {
      padding-bottom: 32px;
    }
  }
  .md\:pb-\[40px\] {
    @media (width >= 48rem) {
      padding-bottom: 40px;
    }
  }
  .md\:pb-\[100px\] {
    @media (width >= 48rem) {
      padding-bottom: 100px;
    }
  }
  .md\:pb-\[150px\] {
    @media (width >= 48rem) {
      padding-bottom: 150px;
    }
  }
  .md\:pl-\[54px\] {
    @media (width >= 48rem) {
      padding-left: 54px;
    }
  }
  .md\:text-start {
    @media (width >= 48rem) {
      text-align: start;
    }
  }
  .md\:text-base {
    @media (width >= 48rem) {
      font-size: var(--text-base);
      line-height: var(--tw-leading, var(--text-base--line-height));
    }
  }
  .md\:text-\[14px\] {
    @media (width >= 48rem) {
      font-size: 14px;
    }
  }
  .md\:text-\[16px\] {
    @media (width >= 48rem) {
      font-size: 16px;
    }
  }
  .md\:text-\[20px\] {
    @media (width >= 48rem) {
      font-size: 20px;
    }
  }
  .md\:text-\[22px\] {
    @media (width >= 48rem) {
      font-size: 22px;
    }
  }
  .md\:text-\[24px\] {
    @media (width >= 48rem) {
      font-size: 24px;
    }
  }
  .md\:text-\[32px\] {
    @media (width >= 48rem) {
      font-size: 32px;
    }
  }
  .md\:text-\[50px\] {
    @media (width >= 48rem) {
      font-size: 50px;
    }
  }
  .md\:text-\[52px\] {
    @media (width >= 48rem) {
      font-size: 52px;
    }
  }
  .md\:leading-\[24px\] {
    @media (width >= 48rem) {
      --tw-leading: 24px;
      line-height: 24px;
    }
  }
  .md\:leading-\[28px\] {
    @media (width >= 48rem) {
      --tw-leading: 28px;
      line-height: 28px;
    }
  }
  .md\:leading-\[32px\] {
    @media (width >= 48rem) {
      --tw-leading: 32px;
      line-height: 32px;
    }
  }
  .md\:leading-\[34px\] {
    @media (width >= 48rem) {
      --tw-leading: 34px;
      line-height: 34px;
    }
  }
  .md\:leading-\[40px\] {
    @media (width >= 48rem) {
      --tw-leading: 40px;
      line-height: 40px;
    }
  }
  .md\:leading-\[68px\] {
    @media (width >= 48rem) {
      --tw-leading: 68px;
      line-height: 68px;
    }
  }
  .md\:font-medium {
    @media (width >= 48rem) {
      --tw-font-weight: var(--font-weight-medium);
      font-weight: var(--font-weight-medium);
    }
  }
  .lg\:mt-0 {
    @media (width >= 64rem) {
      margin-top: calc(var(--spacing) * 0);
    }
  }
  .lg\:block {
    @media (width >= 64rem) {
      display: block;
    }
  }
  .lg\:w-\[50\%\] {
    @media (width >= 64rem) {
      width: 50%;
    }
  }
  .lg\:flex-row {
    @media (width >= 64rem) {
      flex-direction: row;
    }
  }
  .lg\:gap-\[20px\] {
    @media (width >= 64rem) {
      gap: 20px;
    }
  }
  .lg\:px-8 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 8);
    }
  }
  .xl\:block {
    @media (width >= 80rem) {
      display: block;
    }
  }
  .xl\:flex {
    @media (width >= 80rem) {
      display: flex;
    }
  }
  .xl\:hidden {
    @media (width >= 80rem) {
      display: none;
    }
  }
  .xl\:w-\[550px\] {
    @media (width >= 80rem) {
      width: 550px;
    }
  }
  .xl\:max-w-\[1240px\] {
    @media (width >= 80rem) {
      max-width: 1240px;
    }
  }
  .xl\:max-w-\[1250px\] {
    @media (width >= 80rem) {
      max-width: 1250px;
    }
  }
  .xl\:flex-row {
    @media (width >= 80rem) {
      flex-direction: row;
    }
  }
  .xl\:px-0 {
    @media (width >= 80rem) {
      padding-inline: calc(var(--spacing) * 0);
    }
  }
  .xl\:pt-\[213px\] {
    @media (width >= 80rem) {
      padding-top: 213px;
    }
  }
  .xl\:pt-\[247px\] {
    @media (width >= 80rem) {
      padding-top: 247px;
    }
  }
  .xl\:pb-0 {
    @media (width >= 80rem) {
      padding-bottom: calc(var(--spacing) * 0);
    }
  }
  .xl\:pb-\[150px\] {
    @media (width >= 80rem) {
      padding-bottom: 150px;
    }
  }
  .xl\:pb-\[160px\] {
    @media (width >= 80rem) {
      padding-bottom: 160px;
    }
  }
  .\32 xl\:top-\[440px\] {
    @media (width >= 96rem) {
      top: 440px;
    }
  }
  .\32 xl\:m-0 {
    @media (width >= 96rem) {
      margin: calc(var(--spacing) * 0);
    }
  }
  .\32 xl\:-ml-\[52px\] {
    @media (width >= 96rem) {
      margin-left: calc(52px * -1);
    }
  }
  .\32 xl\:-ml-\[80px\] {
    @media (width >= 96rem) {
      margin-left: calc(80px * -1);
    }
  }
  .\32 xl\:ml-0 {
    @media (width >= 96rem) {
      margin-left: calc(var(--spacing) * 0);
    }
  }
  .\32 xl\:h-\[230px\] {
    @media (width >= 96rem) {
      height: 230px;
    }
  }
  .\32 xl\:h-\[800px\] {
    @media (width >= 96rem) {
      height: 800px;
    }
  }
  .\32 xl\:max-w-\[1260px\] {
    @media (width >= 96rem) {
      max-width: 1260px;
    }
  }
  .\32 xl\:max-w-\[1440px\] {
    @media (width >= 96rem) {
      max-width: 1440px;
    }
  }
  .\32 xl\:origin-top-left {
    @media (width >= 96rem) {
      transform-origin: 0 0;
    }
  }
  .\32 xl\:scale-97 {
    @media (width >= 96rem) {
      --tw-scale-x: 97%;
      --tw-scale-y: 97%;
      --tw-scale-z: 97%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }
  }
}
@layer utilities {
  .bg-grad-primary {
    background: linear-gradient(264deg, #163F8F -25.9%, #02ADB1 106.5%);
  }
  .bg-grad-secondary {
    background: linear-gradient(262deg, #163F8F -6.01%, #02ADB1 85.6%);
  }
  .bg-grad-tertiary {
    background: linear-gradient(205deg, #00B6B4 16.02%, #03499A 81.73%);
  }
  .bg-grad-change {
    background: linear-gradient(262deg, #163F8F -6.01%, #02ADB1 85.6%);
    &:hover {
      background: white;
      color: black;
    }
  }
}
@font-face {
  font-family: 'Roboto';
  font-weight: 400;
  src: url(../font/Roboto-Regular.ttf);
}
@font-face {
  font-family: 'Roboto';
  font-weight: 500;
  src: url(../font/Roboto-Medium.ttf);
}
@font-face {
  font-family: 'Roboto';
  font-weight: 600;
  src: url(../font/Roboto-SemiBold.ttf);
}
@font-face {
  font-family: 'Roboto';
  font-weight: 700;
  src: url(../font/Roboto-Bold.ttf);
}
@font-face {
  font-family: 'Fontspring';
  font-weight: 700;
  src: url(../font/Fontspring-DEMO-kanyoncn-bold.otf);
}
@keyframes scrollDown {
  0% {
    opacity: 0;
    transform: translateY(0);
  }
  20% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(10px);
  }
}
.animate-bounce-chevron-1 {
  animation: scrollDown 1.5s ease-in-out infinite;
  animation-delay: 0s;
}
.animate-bounce-chevron-2 {
  animation: scrollDown 1.5s ease-in-out infinite;
  animation-delay: 0s;
}
@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(14px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.animate-slide-up {
  animation: slideUp .35s ease both;
}
@keyframes scrollLeft {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
@keyframes scrollRight {
  0% {
    transform: translateX(-50%);
  }
  100% {
    transform: translateX(0);
  }
}
.timelineTopTrack {
  animation: scrollLeft 60s linear infinite;
}
.timelineBottomTrack {
  animation: scrollRight 60s linear infinite;
}
.pin-ring {
  border: 1px solid rgba(2, 173, 177, 1);
  background: transparent;
  animation: pinRingPulse 1.5s ease-in-out infinite;
  animation-play-state: paused;
}
.pin-dot {
  animation: pinDotPulse 1.5s ease-in-out infinite;
  animation-play-state: paused;
}
@keyframes pinRingPulse {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  100% {
    transform: scale(1.8);
    opacity: 0;
  }
}
@keyframes pinDotPulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.3);
  }
}
html {
  scroll-behavior: smooth;
}
body {
  font-family: 'Roboto', sans-serif;
  color: #212529;
}
.btn-grad {
  position: relative;
  overflow: hidden;
  background: linear-gradient(262deg, #163F8F -6.01%, #02ADB1 85.6%);
  color: white;
  outline: 1.5px solid transparent;
  transition: outline 0.3s ease-in-out, color 0.3s ease-in-out;
}
.btn-grad::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: white;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
  z-index: 0;
}
.btn-grad:hover::after {
  opacity: 1;
}
.btn-grad > * {
  position: relative;
  z-index: 1;
}
.btn-grad .btn-grad-text {
  position: relative;
  z-index: 1;
  background: linear-gradient(262deg, #163F8F -6.01%, #02ADB1 85.6%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}
.btn-grad .btn-white-text {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  transition: opacity 0.3s ease-in-out;
  opacity: 1;
  z-index: 1;
}
.btn-grad:hover .btn-grad-text {
  opacity: 1;
}
.btn-grad:hover .btn-white-text {
  opacity: 0;
}
.btn-grad:hover {
  outline: 1.5px solid #02ADB1;
}
.btn-grad-outline {
  background: linear-gradient(180deg, #163F8F 0%, #02ADB1 80%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.btn-grad-transparent {
  background: transparent !important;
}
.btn-grad-transparent::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(262deg, #163F8F -6.01%, #02ADB1 85.6%);
  transition: opacity 0.3s ease-in-out;
  z-index: 0;
}
.btn-grad-transparent:hover::before {
  opacity: 0;
}
.btn-grad-transparent::after {
  background: transparent !important;
}
.overlap-title {
  background: linear-gradient(to bottom, #ffffff 60%, transparent 100%);
}
.overlap-year {
  background: linear-gradient(to top, #ffffff 20%, transparent 100%);
}
.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  background-size: cover;
  background-position: center;
  transition: opacity 0.8s ease;
}
.hero-slide.active {
  opacity: 1;
}
#track {
  display: flex;
  align-items: flex-end;
  gap: 20px;
  transition: transform 0.5s ease-out;
  will-change: transform;
}
@media (min-width: 1024px) {
  #track {
    gap: 200px;
  }
}
.year-item {
  flex: 0 0 auto;
  min-width: 80px;
  text-align: center;
  cursor: pointer;
  user-select: none;
  position: relative;
  padding: 0;
  margin: 0;
  overflow: visible;
}
.year-label {
  font-size: 90px;
  color: #263B80;
  opacity: 0.2;
  line-height: 1;
  display: block;
  white-space: nowrap;
  transform: scale(0.333);
  transform-origin: center bottom;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), color 0.4s ease;
  margin: 0;
  padding: 0;
}
.year-item.active .year-label {
  font-weight: bold;
  font-size: 90px;
  opacity: 1;
  line-height: 1;
  transform: scale(1);
  background: linear-gradient(180deg, #163F8F 0%, #02ADB1 80%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  padding-right: 0.1em;
  padding-bottom: 0;
  margin-bottom: -0.12em;
}
@media (min-width: 1024px) {
  .year-label {
    font-size: 200px;
    line-height: 1;
    transform: scale(0.4);
  }
  .year-item.active .year-label {
    font-size: 160px;
    line-height: 1;
    transform: scale(1);
    margin-bottom: -0.12em;
  }
}
@media (max-width: 640px) {
  .year-item.active .year-label {
    font-size: 90px;
    line-height: 1;
    margin-bottom: -0.12em;
  }
}
.info-inner {
  transition: opacity 0.45s ease, transform 0.45s ease;
}
.info-inner.visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
.info-title {
  background: linear-gradient(262deg, #163F8F 58.08%, #02ADB1 95.94%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
#track {
  display: flex;
  align-items: flex-end;
  gap: 20px;
  transition: transform 0.5s ease-out;
  will-change: transform;
}
@media (min-width: 1024px) {
  #track {
    gap: 200px;
  }
}
#pagTrack {
  display: flex;
  align-items: center;
  will-change: transform;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  gap: 0px;
  position: relative;
}
.pag-cell {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  position: relative;
  cursor: pointer;
  height: 20px;
}
.pag-cell::before {
  content: '';
  position: absolute;
  left: calc(-1 * (var(--gap-extra, 0px)));
  width: calc(var(--dot-left, 50%) + 5px + var(--gap-extra, 0px));
  height: 2px;
  background: #c9d6e3;
  transition: background 0.5s ease;
  z-index: 0;
}
.pag-cell.past::before, .pag-cell.active::before {
  background: linear-gradient(262deg, #163F8F -6.01%, #02ADB1 85.6%);
}
.pag-cell:first-child::before {
  left: -100vw;
  width: calc(100vw + var(--dot-left, 50%) + 5px);
}
.pag-cell:last-child::before {
  width: auto;
  left: calc(-1 * (var(--gap-extra, 0px)));
  right: -100vw;
}
.pag-cell::after {
  content: '';
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #c9d6e3;
  position: absolute;
  left: var(--dot-left, 50%);
  z-index: 1;
  transition: background 0.5s ease, transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.pag-cell.past::after {
  background: linear-gradient(262deg, #163F8F -6.01%, #02ADB1 85.6%);
}
.pag-cell.active::after {
  background: linear-gradient(262deg, #163F8F -6.01%, #02ADB1 85.6%);
  transform: scale(1.4);
}
@media (max-width: 640px) {
  .year-item.active .year-label {
    font-size: 90px;
  }
}
.pattern-reveal-top, .pattern-reveal-left, .pattern-reveal-right {
  opacity: 0;
  animation-duration: 6s;
  animation-timing-function: cubic-bezier(0.4, 0, 0.2, 0.4);
  animation-fill-mode: forwards;
  animation-play-state: paused;
  animation-delay: 0.1s;
}
.pattern-reveal-middle-left {
  opacity: 0;
  animation-duration: 3s;
  animation-timing-function: cubic-bezier(0.4, 0, 0.2, 0.4);
  animation-fill-mode: forwards;
  animation-play-state: paused;
  animation-delay: 0.1s;
}
.pattern-reveal-middle-right {
  opacity: 0;
  animation-duration: 5s;
  animation-timing-function: cubic-bezier(0.4, 0, 0.2, 0.4);
  animation-fill-mode: forwards;
  animation-play-state: paused;
  animation-delay: 0.1s;
}
.pattern-reveal-top-quick {
  opacity: 0;
  animation-duration: 2s;
  animation-timing-function: cubic-bezier(0.4, 0, 0.2, 0.4);
  animation-fill-mode: forwards;
  animation-play-state: paused;
  animation-delay: 0.1s;
}
.pattern-reveal-top {
  animation-name: revealFromTop;
}
.pattern-reveal-left {
  animation-name: revealFromLeft;
}
.pattern-reveal-right {
  animation-name: revealFromRight;
}
.pattern-reveal-middle-left {
  animation-name: revealFromMiddleLeft;
}
.pattern-reveal-middle-right {
  animation-name: revealFromMiddleRight;
}
.pattern-reveal-top-quick {
  animation-name: revealFromTop;
}
@keyframes revealFromTop {
  0% {
    opacity: 1;
    clip-path: inset(0 0 100% 0);
  }
  100% {
    opacity: 1;
    clip-path: inset(0 0 0% 0);
  }
}
@keyframes revealFromLeft {
  0% {
    opacity: 1;
    clip-path: inset(0 100% 0 0);
  }
  100% {
    opacity: 1;
    clip-path: inset(0 0% 0 0);
  }
}
@keyframes revealFromRight {
  0% {
    opacity: 1;
    clip-path: inset(0 0 0 100%);
  }
  100% {
    opacity: 1;
    clip-path: inset(0 0 0 0%);
  }
}
@keyframes revealFromMiddleLeft {
  0% {
    opacity: 1;
    clip-path: inset(0 0 0 100%);
  }
  100% {
    opacity: 1;
    clip-path: inset(0 0 0 0%);
  }
}
@keyframes revealFromMiddleRight {
  0% {
    opacity: 1;
    clip-path: inset(0 100% 0 0);
  }
  100% {
    opacity: 1;
    clip-path: inset(0 0% 0 0);
  }
}
.reveal-on-scroll {
  opacity: 0;
  transform: translateY(100px);
  transition: opacity 1.5s ease, transform 1.5s ease;
}
.reveal-on-scroll.revealed {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 767px) {
  .event-card {
    box-shadow: 0 0 6px 0 rgba(0, 0, 0, 0.15) !important;
  }
}
@media (min-width: 768px) {
  .event-card {
    box-shadow: 0 0 16px 0 rgba(0, 0, 0, 0.15) !important;
  }
}
@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-duration {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@property --tw-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-border-style: solid;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-duration: initial;
      --tw-ease: initial;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
    }
  }
}
