/* Custom CSS */

*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  margin: 0;
}

@media (prefers-reduced-motion: no-preference) {
  html {
    interpolate-size: allow-keywords;
  }
}

body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

input,
button,
textarea,
select {
  font: inherit;
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

p {
  text-wrap: pretty;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  text-wrap: balance;
}

:root {
  /* Screen sizes */
  --screen-desktop: 1140px;
  /* Color Variables */
  --color-white: rgb(255, 255, 255);
  --color-white-alpha-10: rgb(255, 255, 255, 0.1);
  --color-white-alpha-15: rgb(255, 255, 255, 0.15);
  --color-white-alpha-20: rgb(255, 255, 255, 0.2);
  --color-blue-50: rgb(232, 242, 253);
  --color-blue-100: rgb(209, 229, 250);
  --color-blue-200: rgb(187, 215, 247);
  --color-blue-300: rgb(141, 190, 242);
  --color-blue-400: rgb(94, 163, 237);
  --color-blue-500: rgb(72, 150, 234);
  --color-blue-600: rgb(27, 124, 228);
  --color-blue-700: rgb(22, 99, 182);
  --color-blue-800: rgb(16, 74, 137);
  --color-blue-900: rgb(5, 38, 76);
  --color-green-50: rgb(234, 248, 242);
  --color-green-100: rgb(204, 237, 224);
  --color-green-200: rgb(164, 224, 200);
  --color-green-300: rgb(122, 209, 174);
  --color-green-400: rgb(82, 195, 150);
  --color-green-500: rgb(44, 182, 127);
  --color-green-600: rgb(37, 155, 108);
  --color-green-700: rgb(31, 129, 90);
  --color-green-800: rgb(25, 104, 72);
  --color-green-900: rgb(20, 82, 57);
  --color-purple-50: rgb(244, 238, 253);
  --color-purple-100: rgb(233, 220, 250);
  --color-purple-200: rgb(222, 203, 247);
  --color-purple-300: rgb(208, 181, 244);
  --color-purple-400: rgb(177, 132, 236);
  --color-purple-500: rgb(164, 109, 233);
  --color-purple-600: rgb(146, 80, 229);
  --color-purple-700: rgb(124, 44, 224);
  --color-purple-800: rgb(95, 27, 180);
  --color-purple-900: rgb(56, 9, 122);
  --color-gray-50: rgb(249, 251, 252);
  --color-gray-100: rgb(245, 248, 250);
  --color-gray-200: rgb(237, 241, 245);
  --color-gray-300: rgb(227, 231, 237);
  --color-gray-400: rgb(203, 208, 215);
  --color-gray-500: rgb(176, 182, 191);
  --color-gray-600: rgb(143, 153, 163);
  --color-gray-700: rgb(76, 81, 89);
  --color-gray-800: rgb(45, 50, 56);
  --color-gray-900: rgb(19, 21, 26);
  --color-gray-900-alpha-5: rgb(19, 21, 26, 0.05);
  --color-gray-900-alpha-10: rgb(19, 21, 26, 0.1);
  --color-gray-900-alpha-15: rgb(19, 21, 26, 0.15);
  --color-gray-on-dark-50: rgb(19, 21, 26);
  --color-gray-on-dark-75: rgb(25, 27, 31);
  --color-gray-on-dark-100: rgb(33, 35, 39);
  --color-gray-on-dark-200: rgb(41, 43, 46);
  --color-gray-on-dark-300: rgb(46, 48, 51);
  --color-gray-on-dark-400: rgb(66, 67, 71);
  --color-gray-on-dark-500: rgb(80, 81, 87);
  --color-gray-on-dark-600: rgb(102, 105, 112);
  --color-gray-on-dark-700: rgb(175, 180, 191);
  --color-gray-on-dark-800: rgb(210, 212, 217);
  --color-gray-on-dark-900: rgb(232, 234, 237);
  /* Gradient */
  --linear-blue-tl-rb: linear-gradient(
    110deg,
    rgb(2, 52, 112) 17.76%,
    rgb(6, 30, 59) 71.54%,
    rgb(3, 18, 19) 118.53%
  );
  --linear-blue-t-b: linear-gradient(
    176deg,
    rgb(2, 52, 112) 3.48%,
    rgb(6, 30, 59) 80.76%,
    rgb(3, 18, 19) 232.33%
  );
  --linear-blue-hero: radial-gradient(120% 100% at 50% 0%, #1764B8 0%, #041C30 50%);
  --linear-light-blue-50-t-b: linear-gradient(
    180deg,
    var(--color-blue-50) 0%,
    var(--color-white) 100%
  );
  --linear-light-blue-100-t-b: linear-gradient(
    180deg,
    var(--color-blue-100) 0%,
    var(--color-white) 100%
  );
  --linear-light-blue-50-b-t: linear-gradient(
    180deg,
    var(--color-white) 0%,
    var(--color-blue-50) 100%
  );
  --radial-light-blue: radial-gradient(
    103.08% 24.81% at 50% 0%,
    var(--color-blue-50) 0%,
    var(--color-white) 100%
  );
  /* Shadow */
  /* Color for shadow using Gray 700 */
  --color-shadow-alpha-6: rgb(5, 38, 76, 0.06);
  --color-shadow-alpha-8: rgb(5, 38, 76, 0.08);
  --color-shadow-alpha-12: rgb(5, 38, 76, 0.12);
  --color-shadow-alpha-32: rgb(5, 38, 76, 0.32);
  --color-shadow-alpha-48: rgb(5, 38, 76, 0.48);
  --color-green-800-alpha-32: rgb(25, 104, 72, 0.32);
  --shadow-card: 0px 8px 16px -2px var(--color-shadow-alpha-6),
    0px 4px 8px -1px var(--color-shadow-alpha-8),
    0px 1px 2px 0px var(--color-shadow-alpha-8),
    0px 0px 0px 1px var(--color-shadow-alpha-6);
  --shadow-card-lg: 0px 32px 64px -20px var(--color-shadow-alpha-32),
    0px 16px 32px -8px var(--color-shadow-alpha-12),
    0px 4px 8px -1px var(--color-shadow-alpha-8),
    0px 1px 2px 0px var(--color-shadow-alpha-8),
    0px 0px 0px 1px var(--color-shadow-alpha-6);
  --shadow-card-featured: 0px 24px 48px -12px var(--color-blue-900),
    0px 8px 16px -2px var(--color-shadow-alpha-12),
    0px 4px 8px -1px var(--color-shadow-alpha-8),
    0px 1px 2px 0px var(--color-shadow-alpha-8);
  --shadow-guidebook: 0px 20px 40px -8px var(--color-shadow-alpha-48),
    0px 8px 16px -2px var(--color-shadow-alpha-12),
    0px 4px 8px -1px var(--color-shadow-alpha-8),
    0px 1px 2px 0px var(--color-shadow-alpha-8);
  --shadow-btn: 0px 0px 0px 1px var(--color-shadow-alpha-8),
    0px 1px 2px 0px var(--color-shadow-alpha-12),
    inset 0px 1px 0px var(--color-white);
  --shadow-btn-on-dark: 0px 0px 0px 1px var(--color-white-alpha-20),
    0px 1px 2px 0px var(--color-shadow-alpha-12);
  --shadow-btn-primary: 0px 0px 0px 1px var(--color-green-700),
    0px 1px 2px 0px var(--color-green-800-alpha-32),
    inset 0px 1px 0px var(--color-white-alpha-20);
  --shadow-btn-primary-on-dark: 0px 0px 0px 1px var(--color-green-500),
    0px 1px 2px 0px var(--color-green-400);
  /* Timing variables */
  --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
  --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
  --ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  --ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
  --ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335);
  --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
  --ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1);
  --ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
  --ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1);
  --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
  --ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
  --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1);
  --ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1);
  --ease-in-out-expo: cubic-bezier(1, 0, 0, 1);
  --ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86);
  --font-weight-regular: 400;
  --font-weight-medium: 510;
  --font-weight-semibold: 540;
  --font-weight-bold: 580;
  --font-size-h1:  clamp(2.5rem, 3.306vw + 1.645rem, 4rem);
  --line-height-h1: clamp(3rem, 3.614vw + 2.065rem, 4.64rem);
  --font-size-h2: clamp(2rem, 2.204vw + 1.43rem, 3rem);
  --line-height-h2: clamp(2.4rem, 2.38vw + 1.784rem, 3.48rem);
  --font-size-h3: clamp(1.5rem, 1rem + 2.5vw, 2rem);
  --line-height-h3: clamp(1.8rem, 1.2rem + 3vw, 2.4rem);
  --font-size-h4: clamp(1.375rem, -0.275vw + 1.571rem, 1.5rem);
  --line-height-h4: clamp(1.65rem, -0.198vw + 1.791rem, 1.74rem);
}

*::-moz-selection {
  color: var(--color-gray-900);
  background-color: var(--color-green-200);
}

*::selection {
  color: var(--color-gray-900);
  background-color: var(--color-green-200);
}

[data-theme="dark"] *::-moz-selection {
  color: var(--color-white);
  background-color: var(--color-green-600);
}

[data-theme="dark"] *::selection {
  color: var(--color-white);
  background-color: var(--color-green-600);
}

.hero-animated {
  animation: fadeInBlur 0.72s var(--ease-in-out-quad) both;
  animation-delay: calc(-50ms + var(--animation-order) * 70ms);
}

span.hero-animated {
  display: inline-block;
}

#hero-video.hero-animated {
  animation: fadeInBlurQuick 0.72s var(--ease-in-out-quad) both;
  animation-delay: calc(-50ms + var(--animation-order) * 70ms);
}

@keyframes fadeInBlur {
  from {
    opacity: 0;
    transform: translateY(20%);
    filter: blur(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0%);
    filter: blur(0);
  }
}

@keyframes fadeInBlurQuick {
  from {
    opacity: 0;
    transform: translateY(10%);
    filter: blur(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0%);
    filter: blur(0);
  }
}

footer > nav {
  & dt {
    margin-bottom: 1rem;
  }
  & dt {
    --tw-text-opacity: 1;
    color: rgb(255 255 255 / var(--tw-text-opacity, 1));
  }
  & dt {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
  & dt {
    font-weight: var(--font-weight-medium, 510);
  }
  & dd {
    margin-bottom: 0px;
  }
  & dd > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.75rem * var(--tw-space-y-reverse));
  }
  & dd {
    color: var(--color-gray-on-dark-700) !important;
  }
  & dd {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
  & dd {
    & > a {
      color: var(--color-gray-on-dark-700) !important;
    }
    & > a {
      font-size: 0.875rem;
      line-height: 1.25rem;
    }
    & > a:hover {
      --tw-text-opacity: 1 !important;
      color: rgb(255 255 255 / var(--tw-text-opacity, 1)) !important;
    }
  }
  & dd + dd {
    margin-top: 0.75rem;
  }
  & .address span {
    display: block;
  }
}

/* Overider Element-UI radio button styling */

.el-radio-group {
  display: inline-flex !important;
  align-items: center;
  gap: 0.25rem;
  border-radius: 9999px;
  border-width: 1px;
  border-style: solid;
  border-color: var(--color-gray-300);
  background-color: var(--color-gray-50);
  padding: 0.25rem !important;
  & label {
    margin: 0;
  }
  & label.is-disabled {
    pointer-events: none;
  }
}

.el-radio-button__inner {
  display: inline-flex !important;
  align-items: center;
  border-radius: 9999px !important;
  border-style: none !important;
  background-color: transparent !important;
  padding-left: 0.75rem !important;
  padding-right: 0.75rem !important;
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
  color: var(--color-gray-700) !important;
  font-weight: var(--font-weight-medium, 510) !important;
  font-size: 0.875rem !important;
  line-height: 1 !important;
}

.el-radio-button__inner:hover {
  color: var(--color-gray-800) !important;
}

.el-radio-button:first-child
  > .el-radio-button__orig-radio:checked
  + .el-radio-button__inner {
  box-shadow: var(--shadow-btn) !important;
}

.el-radio-button__orig-radio:checked + .el-radio-button__inner {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  background-color: var(--color-green-50) !important;
  color: var(--color-green-700) !important;
  box-shadow: var(--shadow-btn) !important;
}

.el-radio-button__orig-radio:disabled + .el-radio-button__inner {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  color: var(--color-gray-500) !important;
}

.pricing-card {
  --highlight-height: 1.5rem;
  grid-column: 1 / -1;
  grid-row: span 1 / span 1;
  display: grid;
  background-color: transparent
}

@media (min-width: 1024px) {
  .pricing-card {
    grid-column: span 1 / span 1;
    grid-row: 1 / -1;
    grid-template-rows: subgrid;
  }
}

.pricing-card {
  @media (min-width: 1024px) {
    &:first-of-type {
      border-top-left-radius: var(--highlight-height);
      border-bottom-left-radius: var(--highlight-height);
      border-right-color: transparent;
    }

    &:last-of-type {
      border-top-right-radius: var(--highlight-height);
      border-bottom-right-radius: var(--highlight-height);
      border-left-color: transparent;
    }
  }
}

.pricing-card-recommended {
  position: relative;
  padding-block: var(--highlight-height);
  box-shadow: var(--shadow-card-lg);
  z-index: 2;
  overflow: hidden;
  @media (min-width: 1024px) {
    border-radius: var(--highlight-height);

    margin-block: calc(var(--highlight-height) * -1);
  }
}

.pricing-card-recommended::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: var(--highlight-height);
  background-image: var(--linear-blue-t-b);
}

.pricing-card > * {
  padding: 1.5rem;
  /* If not first div, add border top */
  & + * {
    border-width: 0px !important;
  }
  & + * {
    border-top-width: 1px !important;
  }
  & + * {
    border-style: solid !important;
  }
  & + * {
    border-color: var(--color-gray-300) !important;
  }
}

/* Details smooth height transition */

details {
  overflow: hidden;
}

details::details-content {
  height: 0;
  transition: height 150ms ease, content-visibility 150ms ease;
  transition-behavior: allow-discrete;
}

details[open]::details-content {
  height: auto;
}

/* Toggle icon - vertical line rotates to become minus */

details > summary .toggle-icon svg .vertical-line {
  transform: rotate(0deg);
  transition: transform 150ms ease;
}

details[open] > summary .toggle-icon svg .vertical-line {
  transform: rotate(90deg);
}

table.pricing-table {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 1px;
  width: 100%;
  border: 1px solid var(--color-gray-300);
  border-radius: 1.5rem;
  overflow: hidden;
  thead,
  tbody {
    display: contents;
    /* Makes children participate in parent grid */
  }
  tr {
    display: contents;
    /* Makes th/td direct grid children */
  }
  th,
  td {
    padding: 1.5rem;
  }
  tr.highlight th,
  tr.highlight td {
    background-color: var(--color-green-50);
  }
  tr.highlight th,
  tr.highlight td {
    color: var(--color-gray-800);
  }
  tr.highlight th,
  tr.highlight td {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
  tr.highlight th,
  tr.highlight td {
    font-weight: var(--font-weight-medium, 510);
  }
  th:not(:first-of-type) {
    display: flex;
  }
  th:not(:first-of-type) {
    flex-direction: column;
  }
  th:not(:first-of-type) {
    align-items: center;
  }
  th:not(:first-of-type) {
    border-width: 0px !important;
  }
  th:not(:first-of-type) {
    border-left-width: 1px !important;
  }
  th:not(:first-of-type) {
    border-style: solid;
  }
  th:not(:first-of-type) {
    border-color: var(--color-gray-300);
  }
  td {
    display: flex;
  }
  td {
    align-items: flex-start;
  }
  td {
    border-width: 0px !important;
  }
  td {
    border-top-width: 1px !important;
  }
  td {
    border-style: solid;
  }
  td {
    border-color: var(--color-gray-300);
  }
  td {
    vertical-align: middle;
  }
  td {
    color: var(--color-gray-700);
  }
  td {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }
  td {
    &:first-of-type {
      color: var(--color-gray-800);
    }
    &:first-of-type {
      font-size: 0.875rem;
      line-height: 1.25rem;
    }
    &:first-of-type {
      font-weight: var(--font-weight-medium, 510);
    }
    &:not(:first-of-type) {
      justify-content: center;
    }
    &:not(:first-of-type) {
      border-left-width: 1px !important;
    }
    &:not(:first-of-type) {
      border-style: solid;
    }
    &:not(:first-of-type) {
      border-color: var(--color-gray-300);
    }
  }
}

/* Testimonials Carousel v3 Styles */

.carousel-tw {
  transform: translateX(calc((100% + 8rem) * -1 * var(--position)));
  transition: transform 0.7s var(--ease-out-quad);
}

.carousel-slide {
  grid-column: 1;
  grid-row: 1;
  width: 100%;
  display: flex;
  align-items: center;
  pointer-events: none;
  opacity: 0;
  filter: blur(8px);
  /* All slides share the same grid cell, so they'll have the same height */
  transform: translateX(calc((100% + 8rem) * var(--index)));
  transition: filter 0.4s var(--ease-out-quad),
    opacity 0.2s var(--ease-out-quad);
}

.carousel-slide.active {
  opacity: 1;
  pointer-events: auto;
  filter: blur(0);
}

.carousel-slide blockquote {
  flex: 1;
}

/* Logo Slider v2 Styles */

.logo-slider-wrapper {
  position: relative;
  mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 20%,
    black 80%,
    transparent 100%
  );
  -webkit-mask-image: linear-gradient(
    to right,
    transparent 0%,
    black 20%,
    black 80%,
    transparent 100%
  );
}

.logo-slider {
  --logo-width: 8rem;
  --logo-height: 2rem;
  --logo-gap: 3rem;
  --animation-duration: 60s;
  animation: logoSlide var(--animation-duration) linear infinite;
  filter: blur(0);
  opacity: 1;
  transition-property: filter, opacity;
  transition-duration: 200ms;
  transition-timing-function: var(--ease-out-quad);
}

[data-button-on-hover="true"].logo-slider-wrapper:hover .logo-slider {
  filter: blur(8px);
  opacity: 0.6;
}

/* Filter to mimic the color of gray-800 (light background) and gray-on-dark-900 (dark background) using https://codepen.io/sosuke/pen/Pjoqqp */

.logo-slider-item {
  filter: brightness(0) saturate(100%) invert(9%) sepia(14%) saturate(502%)
    hue-rotate(182deg) brightness(98%) contrast(89%);
  [data-theme="dark"] & {
    filter: brightness(0) saturate(100%) invert(96%) sepia(9%) saturate(58%) hue-rotate(177deg) brightness(97%) contrast(93%);
  }
}

.logo-btn-wrapper {
  opacity: 0;
  transition: opacity 100ms var(--ease-out-quad);
}

[data-button-on-hover="true"].logo-slider-wrapper:hover .logo-btn-wrapper {
  opacity: 1;
  transition: opacity 150ms var(--ease-out-quad);
}

[data-button-on-hover="false"].logo-slider-wrapper:hover .logo-btn-wrapper {
  display: none;
}

@keyframes logoSlide {
  0% {
    transform: translateX(0);
  }

  100% {
    /* Move by exactly half the width (one set of logos) */
    transform: translateX(
      calc(-1 * (var(--logo-width) + var(--logo-gap)) * var(--logo-count))
    );
  }
}

.logo-lower {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
  fill: var(--color-blue-900);
}

[data-theme="dark"] .logo-lower {
  fill: var(--color-white);
}

.logo-upper {
  fill: var(--color-green-600);
}

/*
 * Motion System Tokens
 *
 * ┌─────────────────────────────────────────────────────────────────────────┐
 * │ EASING DECISION GUIDE (for AI & developers)                           │
 * │                                                                       │
 * │ Is the element entering or exiting the viewport?                      │
 * │   → YES: use ease-out  (--motion-enter-*)                             │
 * │   → NO:                                                               │
 * │       Is it moving/morphing on screen (tabs, sliders, indicators)?    │
 * │         → YES: use ease-in-out  (--motion-move-*)                     │
 * │         → NO:                                                         │
 * │             Is it a hover or color change?                            │
 * │               → YES: use ease  (--motion-hover-*)                     │
 * │               → NO:                                                   │
 * │                   Is it a press, toggle, or micro-feedback?           │
 * │                     → YES: use ease-out  (--motion-micro-*)           │
 * │                     → NO:                                             │
 * │                         Is it expanding/collapsing (accordion/panel)? │
 * │                           → YES: use ease-in-out  (--motion-expand-*) │
 * │                           → NO: default to --motion-enter-*           │
 * └─────────────────────────────────────────────────────────────────────────┘
 *
 * DURATION GUIDE
 * --duration-instant  100ms  Micro-feedback: button press, toggle, checkbox
 * --duration-fast     150ms  Hover states, color shifts, small UI changes
 * --duration-normal   200ms  Standard enter/exit: tooltips, dropdowns, toasts
 * --duration-moderate 300ms  Larger motion: modals, drawers, tab indicators
 * --duration-slow     500ms  Full-page transitions, hero animations
 *
 * EASING STRENGTH (weak → strong, defined in global.css)
 * Each family is sorted from subtle to dramatic:
 *   quad < cubic < quart < quint < expo < circ
 *
 * Weaker curves (quad/cubic): subtle, professional, frequent interactions
 * Stronger curves (quint/expo): snappy, dramatic, rare/highlight moments
 *
 * TAILWIND USAGE
 * Easing:   ease-out-quart, ease-in-out-cubic, etc.
 * Duration: duration-instant, duration-fast, duration-normal, etc.
 * Semantic: .transition-enter, .transition-move, .transition-hover, etc.
 *
 * ACCESSIBILITY
 * All durations collapse to 0ms under prefers-reduced-motion: reduce.
 */

:root {
  /* ── Duration tokens ── */
  --duration-instant: 100ms;
  /* micro-feedback: press, toggle, checkbox */
  --duration-fast: 150ms;
  /* hover states, color shifts */
  --duration-normal: 200ms;
  /* standard enter/exit: tooltip, dropdown */
  --duration-moderate: 300ms;
  /* larger motion: modal, drawer, tab slide */
  --duration-slow: 500ms;
  /* page transitions, hero animations */
  /* ── Semantic motion tokens ──
     Pair a use-case with the right easing + duration.
     Raw easing curves live in global.css. */
  /* Enter/exit (dropdowns, tooltips, modals appearing/disappearing)
     ease-out: fast start feels responsive, slow end feels settled */
  --motion-enter-ease: var(--ease-out-quart);
  --motion-enter-duration: var(--duration-normal);
  /* On-screen movement (sliding indicators, tab switches, carousel shifts)
     ease-in-out: accelerate then decelerate like physical objects */
  --motion-move-ease: var(--ease-in-out-quart);
  --motion-move-duration: var(--duration-moderate);
  /* Hover/color shifts (background color, border, text color on hover)
     standard ease: subtle asymmetric curve, never distracting */
  --motion-hover-ease: ease;
  --motion-hover-duration: var(--duration-fast);
  /* Micro-feedback (button press scale, toggle flip, checkbox check)
     ease-out: instant response, no perceptible delay */
  --motion-micro-ease: var(--ease-out-cubic);
  --motion-micro-duration: var(--duration-instant);
  /* Expand/collapse (accordions, drawers, collapsible panels)
     ease-in-out: smooth open and close, no abrupt start or stop */
  --motion-expand-ease: var(--ease-in-out-cubic);
  --motion-expand-duration: var(--duration-moderate);
}

/* Respect user preference: disable all motion by collapsing durations to 0 */

@media (prefers-reduced-motion: reduce) {
  :root {
    --duration-instant: 0ms;
    --duration-fast: 0ms;
    --duration-normal: 0ms;
    --duration-moderate: 0ms;
    --duration-slow: 0ms;
  }
}

/* ── Prose (post/page body) — unlayered to beat Bootstrap/application.css ── */

.blog-prose {
  color: var(--color-gray-800);
}

.blog-prose h2,
.blog-prose h3,
.blog-prose h4,
.blog-prose h5 {
  scroll-margin-top: calc(4rem + 16px);
  color: var(--color-gray-900);
  letter-spacing: -0.022em;
  font-variation-settings: "opsz" 28;
  margin-top: 2.5rem;
  margin-bottom: 0.75rem;
  text-wrap: pretty;
}

.blog-prose h2 {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-semibold, 540);
  line-height: var(--line-height-h3);
}

.blog-prose h3 {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-semibold, 540);
  line-height: var(--line-height-h4);
  font-variation-settings: "opsz" 24;
}

.blog-prose h4,
.blog-prose h5 {
  font-size: 1rem;
  font-weight: var(--font-weight-semibold, 540);
  line-height: 1.5;
  font-variation-settings: "opsz" 22;
}

.blog-prose p {
  font-size: 1.125rem;
  line-height: 1.75;
  margin-bottom: 1.25rem;
}

.blog-prose p:last-child {
  margin-bottom: 0;
}

.blog-prose a {
  color: var(--color-green-700);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.blog-prose a:hover {
  color: var(--color-green-600);
}

.blog-prose strong {
  font-weight: var(--font-weight-bold, 580);
  color: var(--color-gray-900);
}

.blog-prose em {
  font-style: italic;
}

.blog-prose ul,
.blog-prose ol {
  padding-left: 1.5rem;
  margin-bottom: 1.25rem;
}

.blog-prose ul {
  list-style-type: disc;
}

.blog-prose ol {
  list-style-type: decimal;
}

.blog-prose li {
  font-size: 1.125rem;
  line-height: 1.75;
  margin-bottom: 0.375rem;
}

.blog-prose li > ul,
.blog-prose li > ol {
  margin-top: 0.375rem;
  margin-bottom: 0;
}

.blog-prose blockquote {
  border-left: 3px solid var(--color-green-400);
  padding: 0.5rem 0 0.5rem 1.25rem;
  margin: 1.5rem 0;
  color: var(--color-gray-700);
  font-style: italic;
}

.blog-prose blockquote p {
  margin-bottom: 0;
}

.blog-prose hr {
  border: none;
  border-top: 1px solid var(--color-gray-300);
  margin: 2.5rem 0;
}

.blog-prose img {
  width: auto;
  max-width: 100%;
  height: auto;
  border-radius: 0.75rem;
  margin: 1.5rem auto;
  display: block;
}

.blog-prose code,
.blog-prose pre,
.blog-prose kbd {
  font-family: "JetBrains Mono", "SF Mono", "Fira Code", monospace;
}

.blog-prose code {
  font-family: "JetBrains Mono", "SF Mono", "Fira Code", monospace;
  font-size: 0.875em;
  background: var(--color-green-50);
  color: var(--color-green-800);
  border: 1px solid var(--color-green-200);
  border-radius: 4px;
  padding: 0.15em 0.4em;
}

.blog-prose a:has(code) {
  color: inherit;
  text-decoration: none;
}

.blog-prose a:has(code) code::after {
  content: "\f35d";
  font-family: "Font Awesome 5 Pro";
  font-weight: 900;
  font-size: 0.75em;
  margin-left: 0.35em;
  opacity: 0.6;
  vertical-align: middle;
  position: relative;
  top: -0.05em;
}

.blog-prose a:has(code):hover code::after {
  opacity: 1;
}

.blog-prose pre {
  background: var(--color-gray-50);
  color: var(--color-gray-800);
  border: 1px solid var(--color-gray-300);
  border-radius: 0.75rem;
  padding: 1.25rem 1.5rem;
  overflow-x: auto;
  margin: 1.5rem 0;
  font-size: 0.875rem;
  line-height: 1.7;
}

.blog-prose pre code {
  background: none;
  border: none;
  border-radius: 0;
  padding: 0;
  font-size: inherit;
  color: inherit;
}

.blog-prose kbd {
  font-size: 0.8125em;
  background: var(--color-gray-100);
  color: var(--color-gray-900);
  border: 1px solid var(--color-gray-300);
  border-bottom-width: 2px;
  border-radius: 4px;
  padding: 0.1em 0.45em;
  white-space: nowrap;
}

/* ── Syntax highlighting (highlight.js, light theme) — uses project color tokens ── */

.blog-prose pre code.hljs {
  background: none;
  padding: 0;
  color: var(--color-gray-800);
}

.hljs-comment,
.hljs-quote {
  color: var(--color-gray-600);
  font-style: italic;
}

.hljs-keyword,
.hljs-selector-tag,
.hljs-subst {
  color: var(--color-blue-700);
}

.hljs-string,
.hljs-doctag,
.hljs-regexp {
  color: var(--color-green-700);
}

.hljs-number,
.hljs-literal,
.hljs-variable,
.hljs-template-variable {
  color: var(--color-purple-700);
}

.hljs-title,
.hljs-section,
.hljs-selector-id,
.hljs-title.function_ {
  color: var(--color-blue-700);
}

.hljs-type,
.hljs-class .hljs-title,
.hljs-title.class_ {
  color: var(--color-purple-600);
}

.hljs-tag,
.hljs-name,
.hljs-attribute {
  color: var(--color-blue-600);
}

.hljs-attr {
  color: var(--color-green-700);
}

.hljs-built_in,
.hljs-builtin-name {
  color: var(--color-green-700);
}

.hljs-meta,
.hljs-meta .hljs-keyword {
  color: var(--color-gray-600);
}

.hljs-emphasis {
  font-style: italic;
}

.hljs-strong {
  font-weight: var(--font-weight-bold, 580);
}

.hljs-deletion {
  color: var(--color-gray-500);
}

.hljs-addition {
  color: var(--color-green-700);
}

/* ── Callout cards (Ghost kg-callout-card migration) ── */

.blog-callout {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  background: var(--color-green-50);
  border: 1px solid var(--color-green-200);
  border-radius: 0.75rem;
  padding: 1rem 1.25rem;
  margin: 1.5rem 0;
}

.blog-callout__icon {
  flex-shrink: 0;
  width: 1.25rem;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--color-green-600);
  text-align: center;
}

.blog-callout__body {
  flex: 1;
  min-width: 0;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--color-gray-800);
}

.blog-callout__body p {
  margin-bottom: 0;
  font-size: 1rem;
}

.blog-callout__body a {
  color: var(--color-green-700);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.blog-callout__body a:hover {
  color: var(--color-green-600);
}

.blog-callout__body strong {
  font-weight: var(--font-weight-semibold, 540);
  color: var(--color-gray-900);
}

/* ── Float image cards (Ghost aside with img, pullquote-r) ── */

.blog-float-image {
  width: 38%;
  margin: 0.25rem 0 1.25rem;
}

.blog-float-image--right {
  float: right;
  margin-left: 1.75rem;
}

.blog-float-image img {
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
}

@media (max-width: 640px) {
  .blog-float-image {
    float: none;
    width: 60%;
    margin: 1rem auto;
    display: block;
  }
}

/* ── Pullquote cards (Ghost pullquote-r / pullquote-l cards) ── */

.blog-pullquote {
  width: 42%;
  margin: 0.25rem 0 1rem;
  padding: 0;
}

.blog-pullquote--right {
  float: right;
  margin-left: 2rem;
}

.blog-pullquote--left {
  float: left;
  margin-right: 2rem;
}

.blog-pullquote p {
  font-size: 1.375rem;
  font-style: italic;
  font-weight: var(--font-weight-medium, 500);
  line-height: 1.45;
  color: var(--color-green-700);
  margin: 0;
}

@media (max-width: 640px) {
  .blog-pullquote {
    float: none;
    width: 100%;
    margin: 1.25rem 0;
    padding-left: 1rem;
    border-left: 3px solid var(--color-green-400);
  }
}

/* ── Video embeds (Ghost YouTube card migration) ── */

.blog-video-embed {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  /* 16:9 */
  border-radius: 0.75rem;
  overflow: hidden;
  margin: 1.5rem 0;
  background: var(--color-gray-100);
}

.blog-video-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
  border-radius: 0.75rem;
}

.blog-video-native {
  margin: 1.5rem 0;
  border-radius: 0.75rem;
  overflow: hidden;
  background: var(--color-gray-900);
}

.blog-video-native video {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0.75rem;
}

/* ── Wide images (Ghost kg-width-wide — breaks slightly outside prose column) ── */

.blog-prose .blog-img-wide {
  width: calc(100% + 6rem);
  margin-left: -3rem;
  max-width: none;
  border-radius: 0.75rem;
  height: auto;
  display: block;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
}

@media (max-width: 780px) {
  .blog-prose .blog-img-wide {
    width: 100%;
    margin-left: 0;
  }
}

/* ── Raw <video> elements (direct HTML in markdown) ── */

.blog-prose video {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0.75rem;
  margin: 1.5rem 0;
  background: var(--color-gray-900);
}

/* ── Image captions (_italic_ immediately after image) ── */

.blog-prose p:has(> img) > em {
  display: block;
  text-align: center;
  color: var(--color-gray-600);
  font-size: 0.875rem;
  font-style: italic;
  line-height: 1.5;
  margin-top: 0.5rem;
}

/* ── Tables ── */

.blog-prose table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.5rem 0;
  font-size: 0.9375rem;
  line-height: 1.5;
}

.blog-prose thead {
  background: var(--color-gray-100);
}

.blog-prose th {
  text-align: left;
  font-weight: var(--font-weight-semibold, 540);
  color: var(--color-gray-900);
  padding: 0.625rem 1rem;
  border-bottom: 2px solid var(--color-gray-300);
}

.blog-prose td {
  padding: 0.625rem 1rem;
  border-bottom: 1px solid var(--color-gray-200);
  color: var(--color-gray-800);
  vertical-align: top;
}

.blog-prose tbody tr:last-child td {
  border-bottom: none;
}

.blog-prose tbody tr:nth-child(even) {
  background: var(--color-gray-50);
}

/* ── Post layout: 3-column grid ──
   Col 1 (1fr): left gutter — TOC lives here
   Col 2 (≤860px): prose column — header + prose + author all share this, so they align
   Col 3 (1fr): right gutter mirror

   On narrow viewports the grid collapses to block; TOC is hidden. */

.blog-post-layout {
  display: grid;
  grid-template-columns: 1fr minmax(0, 860px) 1fr;
}

@media (max-width: 1399px) {
  .blog-post-layout {
    display: block;
  }
}

/* All content sections go in col 2 */

.blog-post-layout__hero  {
  grid-column: 2;
  grid-row: 1;
}

.blog-post-layout__prose {
  grid-column: 2;
  grid-row: 2;
}

.blog-post-layout__author {
  grid-column: 2;
  grid-row: 3;
}

/* ── Table of Contents (sticky, left column) ── */

/* Hidden by default — JS removes [hidden] when headings are found */

#blog-toc[hidden] {
  display: none;
}

.blog-toc {
  /* Grid placement: col 1, spans prose + author rows */
  grid-column: 1;
  grid-row: 2 / span 2;
  justify-self: start;
  /* left-align within the gutter column */
  margin-left: 16px;
  /* 16px from screen left edge */
  position: sticky;
  top: calc(4rem + 16px);
  /* 4rem = h-16 navbar height */
  align-self: start;
  /* required for sticky inside grid */
  width: 256px;
  max-height: calc(100vh - 4rem - 16px - 24px);
  /* viewport − navbar − top gap − bottom gap */
  overflow-y: auto;
  scrollbar-width: none;
  padding: 0 1rem 2rem 0;
  z-index: 40;
  /* Slide in from left + fade once JS finds headings */
  opacity: 0;
  translate: -8px 0;
  transition:
    opacity var(--motion-enter-duration, 200ms) var(--motion-enter-ease, ease),
    translate var(--motion-enter-duration, 200ms) var(--motion-enter-ease, ease);
  @media (max-width: 1399px) {
    display: none !important;
  }
}

.blog-toc::-webkit-scrollbar {
  display: none;
}

/* JS adds this once the TOC is built */

.blog-toc--ready {
  opacity: 1;
  translate: 0 0;
}

.blog-toc__label {
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  color: var(--color-gray-600);
  margin: 0 0 0.625rem 1rem;
}

/* Track line + item container */

.blog-toc__list {
  position: relative;
  /* anchor for the sliding indicator */
  list-style: none;
  padding: 0;
  margin: 0;
  border-left: 2px solid var(--color-gray-200);
}

/* ── Magnetic sliding indicator ──
   A single element that translates to the active item.
   Uses --motion-move-* (ease-in-out-quart 300ms) for the physical slide feel. */

.blog-toc__indicator {
  position: absolute;
  left: -2px;
  top: 0;
  width: 2px;
  height: 0;
  background: var(--color-green-500);
  border-radius: 1px;
  opacity: 0;
  transition:
    transform var(--motion-move-duration, 300ms) var(--motion-move-ease, ease-in-out),
    height var(--motion-move-duration, 300ms) var(--motion-move-ease, ease-in-out),
    opacity var(--motion-enter-duration, 200ms) var(--motion-enter-ease, ease);
}

.blog-toc__indicator--visible {
  opacity: 1;
}

.blog-toc__item {
  position: relative;
}

.blog-toc__link {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  padding: 0.3rem 0.75rem 0.3rem 1rem;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--color-gray-500);
  text-decoration: none !important;
  transition: color var(--motion-hover-duration, 150ms) var(--motion-hover-ease, ease);
}

.blog-toc__link:hover {
  color: var(--color-gray-800) !important;
}

/* Active link — driven by JS class, not item class, for clean separation */

.blog-toc__link--active {
  color: var(--color-green-700) !important;
  font-weight: 500;
}

/* h3 indented and smaller */

.blog-toc__item--h3 > .blog-toc__link {
  padding-left: 1.5rem;
}

.blog-toc__item--h3 > .blog-toc__link--active {
  color: var(--color-green-600) !important;
}

.blog-tag-scroll {
  overflow-x: auto;
  scrollbar-width: none;
  &::-webkit-scrollbar {
    display: none;
  }
}

/* ── Toolbar ── */

.blog-toolbar {
  container-type: inline-size;
}

.blog-search-wrap {
  position: relative;
  width: 14rem;
  flex-shrink: 0;
}

/* Applied by JS when controls have wrapped to a new row */

.blog-toolbar-controls--wrapped {
  width: 100%;
  .blog-search-wrap {
    flex: 1;
    width: auto;
  }
}

/* Tailwind default config */

*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(147 197 253 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(147 197 253 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

body {
  font-family: Inter, sans-serif !important;
  font-feature-settings: "liga" 1, "calt" 1, "ss03";
}

@supports (font-variation-settings: normal) {
  body {
    font-family: InterVariable, sans-serif !important;
  }
}

h1,
  h2,
  h3,
  h4,
  h5 {
  margin-bottom: 0;
}

strong {
  font-weight: var(--font-weight-bold, 580);
}

button {
  border-width: 0px;
  padding: 0px;
}

button:focus {
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.\!container {
  width: 100% !important;
  margin-right: auto !important;
  margin-left: auto !important;
  padding-right: 16px !important;
  padding-left: 16px !important;
}

.container {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  padding-right: 16px;
  padding-left: 16px;
}

@media (min-width: 640px) {
  .\!container {
    max-width: 640px !important;
  }

  .container {
    max-width: 640px;
  }
}

@media (min-width: 780px) {
  .\!container {
    max-width: 780px !important;
  }

  .container {
    max-width: 780px;
  }
}

@media (min-width: 1024px) {
  .\!container {
    max-width: 1024px !important;
  }

  .container {
    max-width: 1024px;
  }
}

@media (min-width: 1172px) {
  .\!container {
    max-width: 1172px !important;
  }

  .container {
    max-width: 1172px;
  }
}

.btn-tw {
  display: inline-flex;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  border-color: var(--color-border,transparent);
  background-color: var(--color-bg);
  line-height: 1;
  color: var(--color-text) !important;
  font-weight: var(--font-weight-medium);
  transition: transform, background-color, color, border-color, 150ms ease;
}

.btn-tw:active {
  transform: scale(0.97);
}

.btn-tw-lg {
  height: 2.75rem;
  gap: 0.5rem;
  border-radius: 0.75rem;
  padding-left: 1rem;
  padding-right: 1rem;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
  font-weight: var(--font-weight-medium, 510);
  font-size: 1rem;
  line-height: 1;
}

.btn-tw-sm {
  height: 2rem;
  gap: 0.5rem;
  border-radius: 0.5rem;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  font-weight: var(--font-weight-medium, 510);
  line-height: 1;
  font-size: 0.875rem;
}

.btn-tw-primary {
  --color-bg: var(--color-green-600);
  --color-text: var(--color-white);
  box-shadow: var(--shadow-btn-primary);
  &:hover {
    --color-bg: var(--color-green-700);
  }
  &:active {
    --color-bg: var(--color-green-800);
  }
  [data-theme="dark"] & {
    box-shadow: var(--shadow-btn-primary-on-dark);
  }
}

.btn-tw-secondary {
  --color-bg: var(--color-gray-50);
  --color-text: var(--color-gray-800);
  box-shadow: var(--shadow-btn);
  &:hover {
    --color-bg: var(--color-gray-200);
    --color-text: var(--color-gray-900);
  }
  &:active {
    --color-bg: var(--color-gray-200);
  }
  [data-theme="dark"] & {
    --color-bg: var(--color-white-alpha-10);
    --color-text: var(--color-white);
    box-shadow: var(--shadow-btn-on-dark);
    &:hover {
      --color-bg: var(--color-white-alpha-15);
    }
    &:active {
      --color-bg: var(--color-white-alpha-20);
    }
  }
}

.btn-tw-tertiary {
  --color-bg: transparent;
  --color-text: var(--color-gray-700);
  &:hover {
    --color-bg: var(--color-gray-100);
    --color-text: var(--color-gray-900);
  }
  &:active {
    --color-bg: var(--color-gray-200);
  }
  [data-theme="dark"] & {
    --color-text: var(--color-gray-on-dark-800);
    &:hover {
      --color-bg: var(--color-white-alpha-10);
      --color-text: var(--color-white);
    }
    &:active {
      --color-bg: var(--color-white-alpha-15);
    }
  }
  [data-theme="off-white"] & {
    &:hover {
      --color-bg: var(--color-gray-900-alpha-5);
    }
    &:active {
      --color-bg: var(--color-gray-900-alpha-10);
    }
  }
}

.navbar {
  display: flex;
  height: 4rem;
  border-width: 0px !important;
  border-bottom-width: 1px !important;
  border-style: solid;
  border-color: var(--color-gray-300);
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
  padding: 0px !important;
  transition-property: backdrop-filter, color, background-color, border-color;
  transition-timing-function: ease;
  transition-duration: 150ms;
  & .nav-link {
    display: inline-flex;
  }
  & .nav-link {
    cursor: pointer;
  }
  & .nav-link {
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
  }
  & .nav-link {
    align-items: center;
  }
  & .nav-link {
    justify-content: center;
  }
  & .nav-link {
    white-space: nowrap;
  }
  & .nav-link {
    border-color: var(--color-border,transparent);
  }
  & .nav-link {
    background-color: var(--color-bg);
  }
  & .nav-link {
    line-height: 1;
  }
  & .nav-link {
    color: var(--color-text) !important;
  }
  & .nav-link {
    font-weight: var(--font-weight-medium);
    transition: transform, background-color, color, border-color, 150ms ease;
  }
  & .nav-link:active {
    transform: scale(0.97);
  }
  & .nav-link {
    height: 2rem;
  }
  & .nav-link {
    gap: 0.5rem;
  }
  & .nav-link {
    border-radius: 0.5rem;
  }
  & .nav-link {
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }
  & .nav-link {
    font-weight: var(--font-weight-medium, 510);
  }
  & .nav-link {
    font-size: 0.875rem;
    line-height: 1;
  }
  & .nav-link {
    font-size: 0.875rem;
  }
  & .nav-link {
    display: flex;
  }
  & .nav-link {
    gap: 0.25rem;
  }
  & .nav-link {
    --color-text: var(--color-gray-700);
    &:hover {
      --color-bg: var(--color-gray-100);
      --color-text: var(--color-gray-900);
    }
    &:active {
      --color-bg: var(--color-gray-200);
      transform: scale(1);
    }
    [data-theme="dark"] & {
      --color-bg: transparent;
      --color-text: var(--color-gray-on-dark-800);
      &:hover {
        --color-bg: var(--color-white-alpha-10);
        --color-text: var(--color-white);
      }
      &:active {
        --color-bg: var(--color-white-alpha-15);
      }
    }
    [data-theme="off-white"] & {
      &:hover {
        --color-bg: var(--color-gray-900-alpha-5);
      }
      &:active {
        --color-bg: var(--color-gray-900-alpha-10);
      }
    }
  }
  /* Dropdown container - controls visibility on hover */
  .super-dropdown-container {
    position: relative;
    .super-dropdown {
      visibility: hidden;
      opacity: 0;
      transition: all 0.25s ease-in-out;
    }
    &:hover {
      .super-dropdown {
        visibility: visible;
        opacity: 1;
      }
      .nav-link {
        i.fa-angle-down,
          i.far.fa-angle-down {
          transform: rotate(180deg) !important;
        }
      }
    }
  }
  /* Dropdown menu styling */
  .super-dropdown {
    position: fixed;
  }
  .super-dropdown {
    top: 3.5rem;
  }
  .super-dropdown {
    left: 50%;
  }
  .super-dropdown {
    z-index: 10;
  }
  .super-dropdown {
    display: grid;
  }
  .super-dropdown {
    width: 100%;
  }
  .super-dropdown {
    --tw-translate-x: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  }
  .super-dropdown {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .super-dropdown {
    overflow: hidden;
  }
  .super-dropdown {
    border-radius: 1rem;
  }
  .super-dropdown {
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
  }
  .super-dropdown {
    --tw-shadow: var(--shadow-card-lg);
    --tw-shadow-colored: var(--shadow-card-lg);
    box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  }
  .super-dropdown {
    max-width: calc(var(--screen-desktop) - 10rem);
  }
  .super-dropdown-link {
    position: relative;
  }
  .super-dropdown-link {
    isolation: isolate;
  }
  .super-dropdown-link {
    display: flex;
  }
  .super-dropdown-link {
    align-items: flex-start;
  }
  .super-dropdown-link {
    gap: 0.75rem;
  }
  .super-dropdown-link::before,
    .super-dropdown-link::after {
    position: absolute;
  }
  .super-dropdown-link::before,
    .super-dropdown-link::after {
    inset: -0.75rem;
  }
  .super-dropdown-link::before,
    .super-dropdown-link::after {
    border-radius: 0.75rem !important;
  }
  .super-dropdown-link::before,
    .super-dropdown-link::after {
    background-color: transparent;
  }
  .super-dropdown-link::before,
    .super-dropdown-link::after {
    transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
  }
  .super-dropdown-link::before,
    .super-dropdown-link::after {
    content: "";
  }
  .super-dropdown-link::before {
    z-index: -1;
  }
  .super-dropdown-link:hover::before {
    background-color: var(--color-gray-100);
  }
  .super-dropdown-link:active::before {
    background-color: var(--color-gray-200);
  }
  [data-theme="off-white"] .super-dropdown-link:hover::before {
    background-color: var(--color-gray-900-alpha-5);
  }
  [data-theme="off-white"] .super-dropdown-link:active::before {
    background-color: var(--color-gray-900-alpha-10);
  }
  .super-dropdown-icon-wrapper {
    display: flex;
  }
  .super-dropdown-icon-wrapper {
    height: 2.5rem;
  }
  .super-dropdown-icon-wrapper {
    width: 2.5rem;
  }
  .super-dropdown-icon-wrapper {
    flex-shrink: 0;
  }
  .super-dropdown-icon-wrapper {
    align-items: center;
  }
  .super-dropdown-icon-wrapper {
    justify-content: center;
  }
  .super-dropdown-icon-wrapper {
    border-radius: 0.5rem !important;
  }
  .super-dropdown-icon-wrapper {
    border-width: 1px;
  }
  .super-dropdown-icon-wrapper {
    border-color: var(--color-gray-300);
  }
  .super-dropdown-icon-wrapper {
    --tw-bg-opacity: 1;
    background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
  }
  .super-dropdown-icon-wrapper {
    padding: 0.5rem !important;
  }
  .super-dropdown-icon-wrapper {
    box-shadow: var(--shadow-btn);
  }
  /* Nav link hover state for dropdowns */
  & .nav-link {
    i.fa-angle-down,
      i.far.fa-angle-down {
      transition: all 0.2s ease-in;
    }
    &.hovered,
      &:hover {
      i.fa-angle-down,
        i.far.fa-angle-down {
        transform: rotate(180deg) !important;
      }
    }
  }
}

[data-theme="dark"].navbar,
  [data-theme="off-white"].navbar {
  border-bottom-color: transparent;
  background-color: transparent;
  --tw-backdrop-blur: blur(8px);
  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);
}

[data-theme="dark"] #mobile-menu-toggle {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.segmented-control {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  border-radius: 9999px;
  border-width: 1px;
  border-style: solid;
  border-color: var(--color-gray-300);
  background-color: var(--color-gray-50);
  padding: 0.25rem;
  position: relative;
  & label {
    margin: 0;
  }
}

.segmented-control--rounded {
  border-radius: 0.75rem;
}

.segmented-control--flat {
  border-color: transparent;
  background-color: transparent;
  padding: 0px;
  .segmented-control__indicator {
    top: 0px;
  }
  .segmented-control__indicator {
    bottom: 0px;
  }
  .segmented-control__indicator {
    left: 0px;
  }
}

.segmented-control__indicator {
  pointer-events: none;
  position: absolute;
  top: 0.25rem;
  bottom: 0.25rem;
  left: 0.25rem;
  border-radius: 9999px;
  background-color: var(--color-green-50);
  box-shadow: var(--shadow-btn);
  transition: transform var(--motion-move-duration) var(--motion-move-ease),
                width var(--motion-move-duration) var(--motion-move-ease);
  will-change: transform, width;
  z-index: 0;
}

.segmented-control--rounded .segmented-control__indicator {
  border-radius: 0.5rem;
}

.segmented-control__item {
  display: inline-flex;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  align-items: center;
  gap: 0.5rem;
  white-space: nowrap;
  border-radius: 9999px;
  background-color: transparent;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  color: var(--color-gray-700);
  font-weight: var(--font-weight-medium, 510);
  font-size: 0.875rem;
  line-height: 1;
  position: relative;
  z-index: 1;
  transition: color var(--motion-hover-duration) var(--motion-hover-ease);
  &:hover {
    color: var(--color-gray-800);
  }
}

.segmented-control--rounded .segmented-control__item {
  border-radius: 0.5rem;
}

.segmented-control__item--active {
  color: var(--color-green-700);
}

/* ── Stagger entrance animation ── */

@keyframes blog-enter {
  from {
    opacity: 0;
    transform: translateY(8px);
    filter: blur(4px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0px);
  }
}

.blog-entering .blog-post-item,
  .blog-post-item.blog-post-item--entering {
  animation: blog-enter var(--motion-move-duration) var(--motion-move-ease) both;
  animation-delay: calc(var(--i, 0) * 40ms);
}

/* ── Post item: shared base ── */

.blog-post-item {
  text-decoration-line: none;
  color: inherit;
  display: block;
}

.blog-post-item__tag {
  display: inline-flex;
  align-self: flex-start;
  border-radius: 9999px;
  background-color: var(--color-green-100);
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 500;
  color: var(--color-green-800);
}

.blog-post-item__title {
  color: var(--color-gray-900);
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-semibold, 540);
  font-variation-settings: "opsz" 24;
  line-height: var(--line-height-h4);
  letter-spacing: -0.022em;
  transition: color var(--motion-hover-duration) var(--motion-hover-ease);
}

.blog-post-item:hover .blog-post-item__title {
  color: var(--color-green-600);
}

.blog-post-item__desc {
  line-height: 1.625;
  color: var(--color-gray-700);
}

.blog-post-item__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.625rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: var(--color-gray-600);
}

/* ── Grid mode (default) ── */

.blog-grid {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 1.5rem;
}

@media (min-width: 1024px) {
  .blog-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.blog-grid .blog-post-item {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 1rem;
  border-width: 1px;
  border-color: var(--color-gray-300);
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
  --tw-shadow: var(--shadow-card);
  --tw-shadow-colored: var(--shadow-card);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  transition: box-shadow var(--motion-hover-duration) var(--motion-hover-ease),
                transform var(--motion-hover-duration) var(--motion-hover-ease);
}

.blog-grid .blog-post-item:hover {
  --tw-shadow: var(--shadow-card-lg);
  --tw-shadow-colored: var(--shadow-card-lg);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
  transform: translateY(-2px);
}

.blog-grid .blog-post-item__body {
  display: flex;
  flex: 1 1 0%;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1.5rem;
}

.blog-grid .blog-post-item__desc {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.blog-grid .blog-post-item__meta {
  margin-top: auto;
}

.blog-grid .blog-post-item__meta-tag {
  display: none;
}

/* ── List mode ── */

.blog-list {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.blog-list .blog-post-item {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  position: relative;
}

/* Divider between visible items */

.blog-list .blog-post-item--has-divider::before {
  content: '';
  position: absolute;
  top: calc(-1rem - 1px);
  left: 0;
  right: 0;
  height: 1px;
  background: var(--color-gray-300);
}

/* Hover background — full row without shifting text */

.blog-list .blog-post-item::after {
  content: '';
  position: absolute;
  inset: 0 -16px;
  border-radius: 12px;
  background: var(--color-gray-100);
  opacity: 0;
  z-index: -1;
  transition: opacity var(--motion-hover-duration) var(--motion-hover-ease);
}

.blog-list .blog-post-item:hover::after {
  opacity: 1;
}

.blog-list .blog-post-item__image {
  display: none;
}

.blog-list .blog-post-item__tag {
  display: none;
}

.blog-list .blog-post-item__body {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.blog-list .blog-post-item__title {
  font-weight: var(--font-weight-semibold, 540);
  font-variation-settings: "opsz" 22;
  line-height: 1.2;
  letter-spacing: -0.022em;
}

.blog-list .blog-post-item__desc {
  margin-bottom: 0.25rem;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.pointer-events-none {
  pointer-events: none;
}

.pointer-events-auto {
  pointer-events: auto;
}

.visible {
  visibility: visible;
}

.invisible {
  visibility: hidden;
}

.collapse {
  visibility: collapse;
}

.static {
  position: static;
}

.fixed {
  position: fixed;
}

.absolute {
  position: absolute;
}

.relative {
  position: relative;
}

.sticky {
  position: sticky;
}

.inset-0 {
  inset: 0px;
}

.inset-y-0 {
  top: 0px;
  bottom: 0px;
}

.-bottom-12 {
  bottom: -3rem;
}

.-bottom-6 {
  bottom: -1.5rem;
}

.-left-6 {
  left: -1.5rem;
}

.-left-8 {
  left: -2rem;
}

.-right-8 {
  right: -2rem;
}

.-top-16 {
  top: -4rem;
}

.bottom-0 {
  bottom: 0px;
}

.bottom-12 {
  bottom: 3rem;
}

.bottom-3 {
  bottom: 0.75rem;
}

.left-0 {
  left: 0px;
}

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

.left-12 {
  left: 3rem;
}

.left-3 {
  left: 0.75rem;
}

.left-4 {
  left: 1rem;
}

.right-0 {
  right: 0px;
}

.right-12 {
  right: 3rem;
}

.right-3 {
  right: 0.75rem;
}

.right-4 {
  right: 1rem;
}

.top-0 {
  top: 0px;
}

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

.top-16 {
  top: 4rem;
}

.top-32 {
  top: 8rem;
}

.top-36 {
  top: 9rem;
}

.isolate {
  isolation: isolate;
}

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

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

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

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

.col-span-1 {
  grid-column: span 1 / span 1;
}

.col-span-12 {
  grid-column: span 12 / span 12;
}

.col-span-2 {
  grid-column: span 2 / span 2;
}

.col-span-3 {
  grid-column: span 3 / span 3;
}

.col-span-5 {
  grid-column: span 5 / span 5;
}

.col-span-6 {
  grid-column: span 6 / span 6;
}

.col-span-8 {
  grid-column: span 8 / span 8;
}

.col-span-full {
  grid-column: 1 / -1;
}

.col-start-1 {
  grid-column-start: 1;
}

.col-start-2 {
  grid-column-start: 2;
}

.col-start-3 {
  grid-column-start: 3;
}

.col-start-7 {
  grid-column-start: 7;
}

.col-start-8 {
  grid-column-start: 8;
}

.col-end-11 {
  grid-column-end: 11;
}

.col-end-7 {
  grid-column-end: 7;
}

.row-span-1 {
  grid-row: span 1 / span 1;
}

.row-span-2 {
  grid-row: span 2 / span 2;
}

.row-span-full {
  grid-row: 1 / -1;
}

.row-start-1 {
  grid-row-start: 1;
}

.row-start-2 {
  grid-row-start: 2;
}

.float-right {
  float: right;
}

.\!m-0 {
  margin: 0px !important;
}

.m-0 {
  margin: 0px;
}

.m-1 {
  margin: 0.25rem;
}

.m-2 {
  margin: 0.5rem;
}

.m-3 {
  margin: 0.75rem;
}

.m-5 {
  margin: 1.25rem;
}

.mx-0 {
  margin-left: 0px;
  margin-right: 0px;
}

.mx-1 {
  margin-left: 0.25rem;
  margin-right: 0.25rem;
}

.mx-2 {
  margin-left: 0.5rem;
  margin-right: 0.5rem;
}

.mx-3 {
  margin-left: 0.75rem;
  margin-right: 0.75rem;
}

.mx-4 {
  margin-left: 1rem;
  margin-right: 1rem;
}

.mx-5 {
  margin-left: 1.25rem;
  margin-right: 1.25rem;
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.my-12 {
  margin-top: 3rem;
  margin-bottom: 3rem;
}

.my-16 {
  margin-top: 4rem;
  margin-bottom: 4rem;
}

.my-2 {
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

.my-3 {
  margin-top: 0.75rem;
  margin-bottom: 0.75rem;
}

.my-4 {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.my-5 {
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
}

.my-auto {
  margin-top: auto;
  margin-bottom: auto;
}

.\!mb-1 {
  margin-bottom: 0.25rem !important;
}

.\!mb-4 {
  margin-bottom: 1rem !important;
}

.\!mb-6 {
  margin-bottom: 1.5rem !important;
}

.\!mt-4 {
  margin-top: 1rem !important;
}

.-mr-8 {
  margin-right: -2rem;
}

.-mt-16 {
  margin-top: -4rem;
}

.-mt-20 {
  margin-top: -5rem;
}

.mb-0 {
  margin-bottom: 0px;
}

.mb-0\.5 {
  margin-bottom: 0.125rem;
}

.mb-1 {
  margin-bottom: 0.25rem;
}

.mb-10 {
  margin-bottom: 2.5rem;
}

.mb-12 {
  margin-bottom: 3rem;
}

.mb-16 {
  margin-bottom: 4rem;
}

.mb-2 {
  margin-bottom: 0.5rem;
}

.mb-20 {
  margin-bottom: 5rem;
}

.mb-3 {
  margin-bottom: 0.75rem;
}

.mb-4 {
  margin-bottom: 1rem;
}

.mb-5 {
  margin-bottom: 1.25rem;
}

.mb-6 {
  margin-bottom: 1.5rem;
}

.mb-60 {
  margin-bottom: 15rem;
}

.mb-7 {
  margin-bottom: 1.75rem;
}

.mb-8 {
  margin-bottom: 2rem;
}

.me-1 {
  margin-inline-end: 0.25rem;
}

.ml-1 {
  margin-left: 0.25rem;
}

.ml-2 {
  margin-left: 0.5rem;
}

.ml-3 {
  margin-left: 0.75rem;
}

.ml-4 {
  margin-left: 1rem;
}

.ml-auto {
  margin-left: auto;
}

.mr-1 {
  margin-right: 0.25rem;
}

.mr-2 {
  margin-right: 0.5rem;
}

.mr-3 {
  margin-right: 0.75rem;
}

.mr-4 {
  margin-right: 1rem;
}

.mr-auto {
  margin-right: auto;
}

.mt-0 {
  margin-top: 0px;
}

.mt-0\.5 {
  margin-top: 0.125rem;
}

.mt-1 {
  margin-top: 0.25rem;
}

.mt-10 {
  margin-top: 2.5rem;
}

.mt-12 {
  margin-top: 3rem;
}

.mt-2 {
  margin-top: 0.5rem;
}

.mt-20 {
  margin-top: 5rem;
}

.mt-3 {
  margin-top: 0.75rem;
}

.mt-32 {
  margin-top: 8rem;
}

.mt-4 {
  margin-top: 1rem;
}

.mt-48 {
  margin-top: 12rem;
}

.mt-5 {
  margin-top: 1.25rem;
}

.mt-6 {
  margin-top: 1.5rem;
}

.mt-7 {
  margin-top: 1.75rem;
}

.mt-8 {
  margin-top: 2rem;
}

.mt-\[4rem\] {
  margin-top: 4rem;
}

.mt-\[7\.5rem\] {
  margin-top: 7.5rem;
}

.mt-auto {
  margin-top: auto;
}

.block {
  display: block;
}

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

.inline {
  display: inline;
}

.flex {
  display: flex;
}

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

.table {
  display: table;
}

.grid {
  display: grid;
}

.contents {
  display: contents;
}

.hidden {
  display: none;
}

.aspect-\[1432\/748\] {
  aspect-ratio: 1432/748;
}

.h-10 {
  height: 2.5rem;
}

.h-11 {
  height: 2.75rem;
}

.h-12 {
  height: 3rem;
}

.h-16 {
  height: 4rem;
}

.h-24 {
  height: 6rem;
}

.h-3 {
  height: 0.75rem;
}

.h-4 {
  height: 1rem;
}

.h-5 {
  height: 1.25rem;
}

.h-6 {
  height: 1.5rem;
}

.h-8 {
  height: 2rem;
}

.h-\[1\.2em\] {
  height: 1.2em;
}

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

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

.h-\[3lh\] {
  height: 3lh;
}

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

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

.h-\[577\.58px\] {
  height: 577.58px;
}

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

.h-\[var\(--logo-height\)\] {
  height: var(--logo-height);
}

.h-auto {
  height: auto;
}

.h-fit {
  height: -moz-fit-content;
  height: fit-content;
}

.h-full {
  height: 100%;
}

.h-px {
  height: 1px;
}

.max-h-\[640px\] {
  max-height: 640px;
}

.max-h-full {
  max-height: 100%;
}

.min-h-screen {
  min-height: 100vh;
}

.\!w-\[320px\] {
  width: 320px !important;
}

.\!w-full {
  width: 100% !important;
}

.w-10 {
  width: 2.5rem;
}

.w-11 {
  width: 2.75rem;
}

.w-12 {
  width: 3rem;
}

.w-16 {
  width: 4rem;
}

.w-2\/5 {
  width: 40%;
}

.w-24 {
  width: 6rem;
}

.w-3 {
  width: 0.75rem;
}

.w-4 {
  width: 1rem;
}

.w-5 {
  width: 1.25rem;
}

.w-6 {
  width: 1.5rem;
}

.w-8 {
  width: 2rem;
}

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

.w-\[30ch\] {
  width: 30ch;
}

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

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

.w-\[var\(--logo-width\)\] {
  width: var(--logo-width);
}

.w-auto {
  width: auto;
}

.w-fit {
  width: -moz-fit-content;
  width: fit-content;
}

.w-full {
  width: 100%;
}

.w-px {
  width: 1px;
}

.min-w-0 {
  min-width: 0px;
}

.min-w-12 {
  min-width: 3rem;
}

.min-w-60 {
  min-width: 15rem;
}

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

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

.max-w-2xl {
  max-width: 42rem;
}

.max-w-3xl {
  max-width: 48rem;
}

.max-w-4xl {
  max-width: 56rem;
}

.max-w-7xl {
  max-width: 80rem;
}

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

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

.max-w-\[45ch\] {
  max-width: 45ch;
}

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

.max-w-\[90\%\] {
  max-width: 90%;
}

.max-w-blog {
  max-width: 860px;
}

.max-w-blog-content {
  max-width: 760px;
}

.max-w-full {
  max-width: 100%;
}

.max-w-max {
  max-width: -moz-max-content;
  max-width: max-content;
}

.max-w-md {
  max-width: 28rem;
}

.flex-1 {
  flex: 1 1 0%;
}

.flex-shrink {
  flex-shrink: 1;
}

.flex-shrink-0 {
  flex-shrink: 0;
}

.shrink-0 {
  flex-shrink: 0;
}

.flex-grow {
  flex-grow: 1;
}

.grow {
  flex-grow: 1;
}

.border-separate {
  border-collapse: separate;
}

.border-spacing-0 {
  --tw-border-spacing-x: 0px;
  --tw-border-spacing-y: 0px;
  border-spacing: var(--tw-border-spacing-x) var(--tw-border-spacing-y);
}

.origin-center {
  transform-origin: center;
}

.-translate-x-1 {
  --tw-translate-x: -0.25rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-x-1\/2 {
  --tw-translate-x: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-x-full {
  --tw-translate-x: -100%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-1\/2 {
  --tw-translate-y: -50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-64 {
  --tw-translate-y: -16rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.-translate-y-full {
  --tw-translate-y: -100%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-x-full {
  --tw-translate-x: 100%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-y-0 {
  --tw-translate-y: 0px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.translate-y-1\/2 {
  --tw-translate-y: 50%;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.rotate-180 {
  --tw-rotate: 180deg;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.rotate-\[-10deg\] {
  --tw-rotate: -10deg;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.rotate-\[-20deg\] {
  --tw-rotate: -20deg;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-100 {
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-90 {
  --tw-scale-x: .9;
  --tw-scale-y: .9;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.scale-95 {
  --tw-scale-x: .95;
  --tw-scale-y: .95;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.transform {
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.cursor-not-allowed {
  cursor: not-allowed;
}

.cursor-pointer {
  cursor: pointer;
}

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

.resize {
  resize: both;
}

.scroll-mt-32 {
  scroll-margin-top: 8rem;
}

.scroll-mt-40 {
  scroll-margin-top: 10rem;
}

.list-none {
  list-style-type: none;
}

.appearance-none {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.auto-rows-fr {
  grid-auto-rows: minmax(0, 1fr);
}

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

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

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

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

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

.grid-cols-\[0\.75fr_1\.25fr_1\.25fr\] {
  grid-template-columns: 0.75fr 1.25fr 1.25fr;
}

.grid-cols-subgrid {
  grid-template-columns: subgrid;
}

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

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

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

.grid-rows-\[auto-1fr\] {
  grid-template-rows: auto-1fr;
}

.grid-rows-\[auto_1fr\] {
  grid-template-rows: auto 1fr;
}

.grid-rows-\[auto_auto\] {
  grid-template-rows: auto auto;
}

.grid-rows-\[auto_auto_auto_auto\] {
  grid-template-rows: auto auto auto auto;
}

.grid-rows-subgrid {
  grid-template-rows: subgrid;
}

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

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

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

.flex-wrap {
  flex-wrap: wrap;
}

.flex-nowrap {
  flex-wrap: nowrap;
}

.place-items-center {
  place-items: center;
}

.items-start {
  align-items: flex-start;
}

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

.\!items-center {
  align-items: center !important;
}

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

.items-baseline {
  align-items: baseline;
}

.items-stretch {
  align-items: stretch;
}

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

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

.\!justify-center {
  justify-content: center !important;
}

.justify-center {
  justify-content: center;
}

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

.gap-0 {
  gap: 0px;
}

.gap-1 {
  gap: 0.25rem;
}

.gap-12 {
  gap: 3rem;
}

.gap-14 {
  gap: 3.5rem;
}

.gap-16 {
  gap: 4rem;
}

.gap-2 {
  gap: 0.5rem;
}

.gap-2\.5 {
  gap: 0.625rem;
}

.gap-20 {
  gap: 5rem;
}

.gap-3 {
  gap: 0.75rem;
}

.gap-4 {
  gap: 1rem;
}

.gap-6 {
  gap: 1.5rem;
}

.gap-8 {
  gap: 2rem;
}

.gap-\[var\(--logo-gap\)\] {
  gap: var(--logo-gap);
}

.gap-x-10 {
  -moz-column-gap: 2.5rem;
       column-gap: 2.5rem;
}

.gap-x-12 {
  -moz-column-gap: 3rem;
       column-gap: 3rem;
}

.gap-x-6 {
  -moz-column-gap: 1.5rem;
       column-gap: 1.5rem;
}

.gap-x-8 {
  -moz-column-gap: 2rem;
       column-gap: 2rem;
}

.gap-y-10 {
  row-gap: 2.5rem;
}

.gap-y-12 {
  row-gap: 3rem;
}

.gap-y-6 {
  row-gap: 1.5rem;
}

.space-y-12 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(3rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(3rem * var(--tw-space-y-reverse));
}

.space-y-2 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.5rem * var(--tw-space-y-reverse));
}

.space-y-3 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.75rem * var(--tw-space-y-reverse));
}

.space-y-4 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1rem * var(--tw-space-y-reverse));
}

.self-start {
  align-self: flex-start;
}

.self-stretch {
  align-self: stretch;
}

.justify-self-end {
  justify-self: end;
}

.overflow-hidden {
  overflow: hidden;
}

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

.overflow-x-hidden {
  overflow-x: hidden;
}

.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

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

.text-wrap {
  text-wrap: wrap;
}

.text-balance {
  text-wrap: balance;
}

.text-pretty {
  text-wrap: pretty;
}

.\!rounded-md {
  border-radius: 0.375rem !important;
}

.rounded {
  border-radius: 0.25rem;
}

.rounded-2xl {
  border-radius: 1rem;
}

.rounded-3xl {
  border-radius: 1.5rem;
}

.rounded-full {
  border-radius: 9999px;
}

.rounded-lg {
  border-radius: 0.5rem;
}

.rounded-md {
  border-radius: 0.375rem;
}

.rounded-xl {
  border-radius: 0.75rem;
}

.\!border-0 {
  border-width: 0px !important;
}

.border {
  border-width: 1px;
}

.border-0 {
  border-width: 0px;
}

.border-2 {
  border-width: 2px;
}

.\!border-b {
  border-bottom-width: 1px !important;
}

.\!border-l {
  border-left-width: 1px !important;
}

.\!border-t {
  border-top-width: 1px !important;
}

.border-b {
  border-bottom-width: 1px;
}

.border-b-2 {
  border-bottom-width: 2px;
}

.border-l-4 {
  border-left-width: 4px;
}

.border-r {
  border-right-width: 1px;
}

.border-t {
  border-top-width: 1px;
}

.\!border-solid {
  border-style: solid !important;
}

.border-solid {
  border-style: solid;
}

.border-dashed {
  border-style: dashed;
}

.\!border-blue-200 {
  border-color: var(--color-blue-200) !important;
}

.\!border-blue-300 {
  border-color: var(--color-blue-300) !important;
}

.\!border-gray-300 {
  border-color: var(--color-gray-300) !important;
}

.\!border-green-200 {
  border-color: var(--color-green-200) !important;
}

.\!border-green-300 {
  border-color: var(--color-green-300) !important;
}

.\!border-green-600 {
  border-color: var(--color-green-600) !important;
}

.\!border-white\/15 {
  border-color: rgb(255 255 255 / 0.15) !important;
}

.border-blue-200 {
  border-color: var(--color-blue-200);
}

.border-blue-500 {
  border-color: var(--color-blue-500);
}

.border-gray-100 {
  border-color: var(--color-gray-100);
}

.border-gray-200 {
  border-color: var(--color-gray-200);
}

.border-gray-300 {
  border-color: var(--color-gray-300);
}

.border-gray-400 {
  border-color: var(--color-gray-400);
}

.border-green-200 {
  border-color: var(--color-green-200);
}

.border-green-500 {
  border-color: var(--color-green-500);
}

.border-green-600 {
  border-color: var(--color-green-600);
}

.border-transparent {
  border-color: transparent;
}

.border-white\/20 {
  border-color: rgb(255 255 255 / 0.2);
}

.border-zinc-200 {
  --tw-border-opacity: 1;
  border-color: rgb(228 228 231 / var(--tw-border-opacity, 1));
}

.border-zinc-300 {
  --tw-border-opacity: 1;
  border-color: rgb(212 212 216 / var(--tw-border-opacity, 1));
}

.\!border-b-white\/10 {
  border-bottom-color: rgb(255 255 255 / 0.1) !important;
}

.bg-\[\#00192D\] {
  --tw-bg-opacity: 1;
  background-color: rgb(0 25 45 / var(--tw-bg-opacity, 1));
}

.bg-black\/20 {
  background-color: rgb(0 0 0 / 0.2);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

.bg-red-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 226 226 / var(--tw-bg-opacity, 1));
}

.bg-red-50 {
  --tw-bg-opacity: 1;
  background-color: rgb(254 242 242 / var(--tw-bg-opacity, 1));
}

.bg-transparent {
  background-color: transparent;
}

.bg-white {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.bg-white\/10 {
  background-color: rgb(255 255 255 / 0.1);
}

.bg-zinc-100 {
  --tw-bg-opacity: 1;
  background-color: rgb(244 244 245 / var(--tw-bg-opacity, 1));
}

.bg-zinc-200 {
  --tw-bg-opacity: 1;
  background-color: rgb(228 228 231 / var(--tw-bg-opacity, 1));
}

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

.bg-linear-blue-t-b {
  background-image: var(--linear-blue-t-b);
}

.bg-linear-blue-tl-rb {
  background-image: var(--linear-blue-tl-rb);
}

.bg-linear-light-blue-50-t-b {
  background-image: var(--linear-light-blue-50-t-b);
}

.bg-radial-light-blue {
  background-image: var(--radial-light-blue);
}

.\!from-green-200 {
  --tw-gradient-from: var(--color-green-200) var(--tw-gradient-from-position) !important;
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position) !important;
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important;
}

.\!from-green-300 {
  --tw-gradient-from: var(--color-green-300) var(--tw-gradient-from-position) !important;
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position) !important;
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important;
}

.from-blue-50 {
  --tw-gradient-from: var(--color-blue-50) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-green-200 {
  --tw-gradient-from: var(--color-green-200) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-green-50 {
  --tw-gradient-from: var(--color-green-50) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-purple-50 {
  --tw-gradient-from: var(--color-purple-50) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-white {
  --tw-gradient-from: #fff var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.from-white\/10 {
  --tw-gradient-from: rgb(255 255 255 / 0.1) var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.\!to-green-500 {
  --tw-gradient-to: var(--color-green-500) var(--tw-gradient-to-position) !important;
}

.to-blue-100 {
  --tw-gradient-to: var(--color-blue-100) var(--tw-gradient-to-position);
}

.to-green-100 {
  --tw-gradient-to: var(--color-green-100) var(--tw-gradient-to-position);
}

.to-green-500 {
  --tw-gradient-to: var(--color-green-500) var(--tw-gradient-to-position);
}

.to-white {
  --tw-gradient-to: #fff var(--tw-gradient-to-position);
}

.to-white\/15 {
  --tw-gradient-to: rgb(255 255 255 / 0.15) var(--tw-gradient-to-position);
}

.to-white\/80 {
  --tw-gradient-to: rgb(255 255 255 / 0.8) var(--tw-gradient-to-position);
}

.bg-cover {
  background-size: cover;
}

.bg-clip-text {
  -webkit-background-clip: text;
          background-clip: text;
}

.bg-center {
  background-position: center;
}

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

.fill-blue-200 {
  fill: var(--color-blue-200);
}

.fill-gray-400 {
  fill: var(--color-gray-400);
}

.fill-green-200 {
  fill: var(--color-green-200);
}

.fill-purple-200 {
  fill: var(--color-purple-200);
}

.stroke-blue-300 {
  stroke: var(--color-blue-300);
}

.stroke-gray-600 {
  stroke: var(--color-gray-600);
}

.stroke-gray-700 {
  stroke: var(--color-gray-700);
}

.stroke-green-600 {
  stroke: var(--color-green-600);
}

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

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

.object-left {
  -o-object-position: left;
     object-position: left;
}

.\!p-0 {
  padding: 0px !important;
}

.\!p-1 {
  padding: 0.25rem !important;
}

.\!p-3 {
  padding: 0.75rem !important;
}

.p-0 {
  padding: 0px;
}

.p-1 {
  padding: 0.25rem;
}

.p-12 {
  padding: 3rem;
}

.p-16 {
  padding: 4rem;
}

.p-2 {
  padding: 0.5rem;
}

.p-3 {
  padding: 0.75rem;
}

.p-4 {
  padding: 1rem;
}

.p-5 {
  padding: 1.25rem;
}

.p-6 {
  padding: 1.5rem;
}

.p-8 {
  padding: 2rem;
}

.\!px-2 {
  padding-left: 0.5rem !important;
  padding-right: 0.5rem !important;
}

.\!px-3 {
  padding-left: 0.75rem !important;
  padding-right: 0.75rem !important;
}

.\!px-4 {
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

.\!py-2 {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}

.\!py-4 {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}

.\!py-5 {
  padding-top: 1.25rem !important;
  padding-bottom: 1.25rem !important;
}

.px-0 {
  padding-left: 0px;
  padding-right: 0px;
}

.px-2 {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.px-2\.5 {
  padding-left: 0.625rem;
  padding-right: 0.625rem;
}

.px-3 {
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}

.px-4 {
  padding-left: 1rem;
  padding-right: 1rem;
}

.px-5 {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

.px-6 {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

.py-1 {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
}

.py-1\.5 {
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
}

.py-12 {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.py-16 {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.py-2 {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.py-2\.5 {
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
}

.py-20 {
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.py-3 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.py-32 {
  padding-top: 8rem;
  padding-bottom: 8rem;
}

.py-4 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.py-5 {
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
}

.py-6 {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}

.py-8 {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.py-\[7\.5rem\] {
  padding-top: 7.5rem;
  padding-bottom: 7.5rem;
}

.\!pb-5 {
  padding-bottom: 1.25rem !important;
}

.pb-0 {
  padding-bottom: 0px;
}

.pb-1 {
  padding-bottom: 0.25rem;
}

.pb-12 {
  padding-bottom: 3rem;
}

.pb-14 {
  padding-bottom: 3.5rem;
}

.pb-16 {
  padding-bottom: 4rem;
}

.pb-2 {
  padding-bottom: 0.5rem;
}

.pb-20 {
  padding-bottom: 5rem;
}

.pb-3 {
  padding-bottom: 0.75rem;
}

.pb-4 {
  padding-bottom: 1rem;
}

.pb-5 {
  padding-bottom: 1.25rem;
}

.pb-6 {
  padding-bottom: 1.5rem;
}

.pb-\[7\.5rem\] {
  padding-bottom: 7.5rem;
}

.pl-0 {
  padding-left: 0px;
}

.pl-3 {
  padding-left: 0.75rem;
}

.pl-4 {
  padding-left: 1rem;
}

.pl-6 {
  padding-left: 1.5rem;
}

.pl-9 {
  padding-left: 2.25rem;
}

.pr-0 {
  padding-right: 0px;
}

.pr-3 {
  padding-right: 0.75rem;
}

.pr-5 {
  padding-right: 1.25rem;
}

.pt-0 {
  padding-top: 0px;
}

.pt-1 {
  padding-top: 0.25rem;
}

.pt-10 {
  padding-top: 2.5rem;
}

.pt-12 {
  padding-top: 3rem;
}

.pt-16 {
  padding-top: 4rem;
}

.pt-2 {
  padding-top: 0.5rem;
}

.pt-20 {
  padding-top: 5rem;
}

.pt-3 {
  padding-top: 0.75rem;
}

.pt-32 {
  padding-top: 8rem;
}

.pt-4 {
  padding-top: 1rem;
}

.pt-5 {
  padding-top: 1.25rem;
}

.pt-6 {
  padding-top: 1.5rem;
}

.pt-8 {
  padding-top: 2rem;
}

.pt-\[7\.5rem\] {
  padding-top: 7.5rem;
}

.pt-\[calc\(4rem\+7\.5rem\)\] {
  padding-top: calc(4rem + 7.5rem);
}

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

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

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

.text-2xl {
  font-size: 1.5rem;
  line-height: 2rem;
}

.text-3xl {
  font-size: 1.875rem;
  line-height: 2.25rem;
}

.text-4xl {
  font-size: 2.25rem;
  line-height: 2.5rem;
}

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

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

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

.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}

.text-lg {
  font-size: 1.125rem;
  line-height: 1.75rem;
}

.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}

.text-xs {
  font-size: 0.75rem;
  line-height: 1rem;
}

.font-bold {
  font-weight: 700;
}

.font-medium {
  font-weight: 500;
}

.font-normal {
  font-weight: 400;
}

.font-semibold {
  font-weight: 600;
}

.uppercase {
  text-transform: uppercase;
}

.italic {
  font-style: italic;
}

.\!leading-normal {
  line-height: 1.5 !important;
}

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

.leading-relaxed {
  line-height: 1.625;
}

.leading-tight {
  line-height: 1.25;
}

.tracking-\[0\.1em\] {
  letter-spacing: 0.1em;
}

.\!text-blue-600 {
  color: var(--color-blue-600) !important;
}

.\!text-gray-600 {
  color: var(--color-gray-600) !important;
}

.\!text-gray-700 {
  color: var(--color-gray-700) !important;
}

.\!text-gray-800 {
  color: var(--color-gray-800) !important;
}

.\!text-green-600 {
  color: var(--color-green-600) !important;
}

.\!text-green-800 {
  color: var(--color-green-800) !important;
}

.text-black {
  --tw-text-opacity: 1;
  color: rgb(0 0 0 / var(--tw-text-opacity, 1));
}

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

.text-blue-700 {
  color: var(--color-blue-700);
}

.text-blue-800 {
  color: var(--color-blue-800);
}

.text-blue-900 {
  color: var(--color-blue-900);
}

.text-emerald-400 {
  --tw-text-opacity: 1;
  color: rgb(52 211 153 / var(--tw-text-opacity, 1));
}

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

.text-gray-600 {
  color: var(--color-gray-600);
}

.text-gray-700 {
  color: var(--color-gray-700);
}

.text-gray-800 {
  color: var(--color-gray-800);
}

.text-gray-900 {
  color: var(--color-gray-900);
}

.text-gray-on-dark-700 {
  color: var(--color-gray-on-dark-700);
}

.text-gray-on-dark-800 {
  color: var(--color-gray-on-dark-800);
}

.text-green-400 {
  color: var(--color-green-400);
}

.text-green-500 {
  color: var(--color-green-500);
}

.text-green-600 {
  color: var(--color-green-600);
}

.text-green-700 {
  color: var(--color-green-700);
}

.text-green-800 {
  color: var(--color-green-800);
}

.text-purple-600 {
  color: var(--color-purple-600);
}

.text-red-600 {
  --tw-text-opacity: 1;
  color: rgb(220 38 38 / var(--tw-text-opacity, 1));
}

.text-transparent {
  color: transparent;
}

.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.text-white\/70 {
  color: rgb(255 255 255 / 0.7);
}

.text-white\/80 {
  color: rgb(255 255 255 / 0.8);
}

.text-white\/95 {
  color: rgb(255 255 255 / 0.95);
}

.underline {
  text-decoration-line: underline;
}

.line-through {
  text-decoration-line: line-through;
}

.no-underline {
  text-decoration-line: none;
}

.opacity-0 {
  opacity: 0;
}

.opacity-100 {
  opacity: 1;
}

.opacity-30 {
  opacity: 0.3;
}

.opacity-50 {
  opacity: 0.5;
}

.opacity-60 {
  opacity: 0.6;
}

.shadow {
  --tw-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-card {
  --tw-shadow: var(--shadow-card);
  --tw-shadow-colored: var(--shadow-card);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-card-featured {
  --tw-shadow: var(--shadow-card-featured);
  --tw-shadow-colored: var(--shadow-card-featured);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-card-lg {
  --tw-shadow: var(--shadow-card-lg);
  --tw-shadow-colored: var(--shadow-card-lg);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-guidebook {
  --tw-shadow: var(--shadow-guidebook);
  --tw-shadow-colored: var(--shadow-guidebook);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-lg {
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-md {
  --tw-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.shadow-sm {
  --tw-shadow: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.outline-none {
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.outline {
  outline-style: solid;
}

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

.backdrop-blur-sm {
  --tw-backdrop-blur: blur(4px);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}

.transition {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-all {
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-colors {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-shadow {
  transition-property: box-shadow;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-transform {
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.duration-200 {
  transition-duration: 200ms;
}

.duration-300 {
  transition-duration: 300ms;
}

.duration-500 {
  transition-duration: 500ms;
}

.ease-in-out {
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.ease-out {
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}

.text-h1 {
  font-size: var(--font-size-h1);
  font-weight: var(--font-weight-medium, 510) !important;
  font-variation-settings: "opsz" 28;
  line-height: var(--line-height-h1);
  letter-spacing: -0.022em;
}

.text-h2 {
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-semibold, 540) !important;
  font-variation-settings: "opsz" 28;
  line-height: var(--line-height-h2);
  letter-spacing: -0.022em;
}

.text-h3 {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-semibold, 540) !important;
  font-variation-settings: "opsz" 28;
  line-height: var(--line-height-h3);
  letter-spacing: -0.022em;
}

.text-h4 {
  font-size: var(--font-size-h4);
  font-weight: var(--font-weight-semibold, 540) !important;
  font-variation-settings: "opsz" 24;
  line-height: var(--line-height-h4);
  letter-spacing: -0.022em;
}

.text-body-regular,
  .text-body-medium {
  font-size: 1.125rem;
  line-height: 1.5;
}

.text-caption-md-regular,
  .text-caption-md-medium {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.text-caption-lg-regular,
  .text-caption-lg-medium {
  font-size: 1rem;
  line-height: 1.5rem;
}

.text-caption-sm-regular {
  font-size: 0.8125rem;
  line-height: 1.25rem;
}

.text-caption- .text-body-medium,
  .text-caption-md-medium,
  .text-caption-lg-medium,
  .text-label-lg,
  .text-label-md,
  .text-label-sm,
  .text-label-mobile {
  font-weight: var(--font-weight-medium, 510) !important;
}

.text-label-mobile {
  font-size: 1.5rem;
  line-height: 1.3;
}

.text-label-lg {
  font-size: 1rem;
  line-height: 1;
}

.text-label-md {
  font-size: 0.875rem;
  line-height: 1;
}

.text-featured {
  font-size: 1.25rem;
  line-height: 1.5;
  font-weight: var(--font-weight-medium, 510) !important;
}

/* Semantic transition shorthands — apply to transition-property of your choice.
     Example: class="transition-[transform,opacity] transition-enter" */

.before\:content-\[\'\"\'\]::before {
  --tw-content: '"';
  content: var(--tw-content);
}

.before\:content-\[\'\\\"\'\]::before {
  --tw-content: '\"';
  content: var(--tw-content);
}

.before\:content-\[\'\201C\'\]::before {
  --tw-content: '“';
  content: var(--tw-content);
}

.after\:content-\[\'\"\'\]::after {
  --tw-content: '"';
  content: var(--tw-content);
}

.after\:content-\[\'\\\"\'\]::after {
  --tw-content: '\"';
  content: var(--tw-content);
}

.after\:content-\[\'\201D\'\]::after {
  --tw-content: '”';
  content: var(--tw-content);
}

.hover\:cursor-pointer:hover {
  cursor: pointer;
}

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

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

.hover\:bg-white\/20:hover {
  background-color: rgb(255 255 255 / 0.2);
}

.hover\:\!text-blue-700:hover {
  color: var(--color-blue-700) !important;
}

.hover\:\!text-green-600:hover {
  color: var(--color-green-600) !important;
}

.hover\:\!text-green-700:hover {
  color: var(--color-green-700) !important;
}

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

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

.hover\:\!underline:hover {
  text-decoration-line: underline !important;
}

.hover\:shadow-card-lg:hover {
  --tw-shadow: var(--shadow-card-lg);
  --tw-shadow-colored: var(--shadow-card-lg);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.focus\:border-green-600:focus {
  border-color: var(--color-green-600);
}

.focus\:outline-green-600:focus {
  outline-color: var(--color-green-600);
}

.focus\:ring-1:focus {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000);
}

.focus\:ring-green-600:focus {
  --tw-ring-color: var(--color-green-600);
}

.active\:\!text-green-800:active {
  color: var(--color-green-800) !important;
}

.group:hover .group-hover\:translate-x-0 {
  --tw-translate-x: 0px;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.group:hover .group-hover\:\!text-green-600 {
  color: var(--color-green-600) !important;
}

.group:hover .group-hover\:text-green-600 {
  color: var(--color-green-600);
}

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

.group[data-theme="dark"] .group-data-\[theme\=dark\]\:\!border-white\/15 {
  border-color: rgb(255 255 255 / 0.15) !important;
}

.group[data-theme="dark"] .group-data-\[theme\=dark\]\:\!bg-white\/10 {
  background-color: rgb(255 255 255 / 0.1) !important;
}

.group[data-active="true"] .group-data-\[active\=true\]\:\!text-gray-800 {
  color: var(--color-gray-800) !important;
}

.group[data-theme="dark"] .group-data-\[theme\=dark\]\:text-gray-on-dark-700 {
  color: var(--color-gray-on-dark-700);
}

.group[data-theme="dark"] .group-data-\[theme\=dark\]\:text-gray-on-dark-800 {
  color: var(--color-gray-on-dark-800);
}

.group[data-theme="dark"] .group-data-\[theme\=dark\]\:text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

@media (min-width: 640px) {
  .sm\:-mt-32 {
    margin-top: -8rem;
  }

  .sm\:mt-0 {
    margin-top: 0px;
  }

  .sm\:mt-56 {
    margin-top: 14rem;
  }

  .sm\:block {
    display: block;
  }

  .sm\:min-w-\[300px\] {
    min-width: 300px;
  }

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

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

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

  .sm\:items-center {
    align-items: center;
  }

  .sm\:justify-center {
    justify-content: center;
  }

  .sm\:px-0 {
    padding-left: 0px;
    padding-right: 0px;
  }

  .sm\:px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

@media (min-width: 780px) {
  .md\:col-span-2 {
    grid-column: span 2 / span 2;
  }

  .md\:col-span-3 {
    grid-column: span 3 / span 3;
  }

  .md\:col-start-10 {
    grid-column-start: 10;
  }

  .md\:col-start-2 {
    grid-column-start: 2;
  }

  .md\:row-span-1 {
    grid-row: span 1 / span 1;
  }

  .md\:row-span-3 {
    grid-row: span 3 / span 3;
  }

  .md\:row-start-auto {
    grid-row-start: auto;
  }

  .md\:-mt-40 {
    margin-top: -10rem;
  }

  .md\:mb-2 {
    margin-bottom: 0.5rem;
  }

  .md\:mb-20 {
    margin-bottom: 5rem;
  }

  .md\:mt-0 {
    margin-top: 0px;
  }

  .md\:mt-20 {
    margin-top: 5rem;
  }

  .md\:mt-64 {
    margin-top: 16rem;
  }

  .md\:block {
    display: block;
  }

  .md\:flex {
    display: flex;
  }

  .md\:grid {
    display: grid;
  }

  .md\:hidden {
    display: none;
  }

  .md\:h-10 {
    height: 2.5rem;
  }

  .md\:w-1\/2 {
    width: 50%;
  }

  .md\:w-2\/3 {
    width: 66.666667%;
  }

  .md\:w-20 {
    width: 5rem;
  }

  .md\:w-auto {
    width: auto;
  }

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

  .md\:max-w-\[23ch\] {
    max-width: 23ch;
  }

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

  .md\:flex-1 {
    flex: 1 1 0%;
  }

  .md\:-translate-y-1\/2 {
    --tw-translate-y: -50%;
    transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  }

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

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

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

  .md\:grid-cols-\[1\.5fr_1fr\] {
    grid-template-columns: 1.5fr 1fr;
  }

  .md\:grid-cols-\[1fr_1\.5fr\] {
    grid-template-columns: 1fr 1.5fr;
  }

  .md\:grid-cols-subgrid {
    grid-template-columns: subgrid;
  }

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

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

  .md\:grid-rows-3 {
    grid-template-rows: repeat(3, minmax(0, 1fr));
  }

  .md\:grid-rows-\[auto_1fr_auto\] {
    grid-template-rows: auto 1fr auto;
  }

  .md\:grid-rows-subgrid {
    grid-template-rows: subgrid;
  }

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

  .md\:justify-between {
    justify-content: space-between;
  }

  .md\:gap-6 {
    gap: 1.5rem;
  }

  .md\:gap-x-20 {
    -moz-column-gap: 5rem;
         column-gap: 5rem;
  }

  .md\:space-y-3 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(0.75rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(0.75rem * var(--tw-space-y-reverse));
  }

  .md\:p-12 {
    padding: 3rem;
  }

  .md\:p-8 {
    padding: 2rem;
  }

  .md\:px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .md\:px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .md\:py-24 {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }

  .md\:pb-40 {
    padding-bottom: 10rem;
  }

  .md\:pb-8 {
    padding-bottom: 2rem;
  }

  .md\:pr-12 {
    padding-right: 3rem;
  }

  .md\:pt-\[calc\(4rem\+7\.5rem\)\] {
    padding-top: calc(4rem + 7.5rem);
  }

  .md\:\!text-left {
    text-align: left !important;
  }

  .md\:text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }

  .md\:text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }

  .md\:text-base {
    font-size: 1rem;
    line-height: 1.5rem;
  }

  .md\:text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
}

@media (min-width: 1024px) {
  .lg\:absolute {
    position: absolute;
  }

  .lg\:-bottom-8 {
    bottom: -2rem;
  }

  .lg\:bottom-8 {
    bottom: 2rem;
  }

  .lg\:left-0 {
    left: 0px;
  }

  .lg\:left-8 {
    left: 2rem;
  }

  .lg\:right-0 {
    right: 0px;
  }

  .lg\:right-8 {
    right: 2rem;
  }

  .lg\:top-1 {
    top: 0.25rem;
  }

  .lg\:col-span-1 {
    grid-column: span 1 / span 1;
  }

  .lg\:col-span-10 {
    grid-column: span 10 / span 10;
  }

  .lg\:col-span-3 {
    grid-column: span 3 / span 3;
  }

  .lg\:col-span-5 {
    grid-column: span 5 / span 5;
  }

  .lg\:col-span-6 {
    grid-column: span 6 / span 6;
  }

  .lg\:col-span-8 {
    grid-column: span 8 / span 8;
  }

  .lg\:col-span-9 {
    grid-column: span 9 / span 9;
  }

  .lg\:col-start-1 {
    grid-column-start: 1;
  }

  .lg\:col-start-2 {
    grid-column-start: 2;
  }

  .lg\:col-start-3 {
    grid-column-start: 3;
  }

  .lg\:col-start-4 {
    grid-column-start: 4;
  }

  .lg\:col-start-8 {
    grid-column-start: 8;
  }

  .lg\:col-start-9 {
    grid-column-start: 9;
  }

  .lg\:col-end-13 {
    grid-column-end: 13;
  }

  .lg\:col-end-6 {
    grid-column-end: 6;
  }

  .lg\:col-end-9 {
    grid-column-end: 9;
  }

  .lg\:row-span-2 {
    grid-row: span 2 / span 2;
  }

  .lg\:row-start-1 {
    grid-row-start: 1;
  }

  .lg\:-mt-56 {
    margin-top: -14rem;
  }

  .lg\:-mt-64 {
    margin-top: -16rem;
  }

  .lg\:mb-0 {
    margin-bottom: 0px;
  }

  .lg\:mb-20 {
    margin-bottom: 5rem;
  }

  .lg\:mb-28 {
    margin-bottom: 7rem;
  }

  .lg\:mt-0 {
    margin-top: 0px;
  }

  .lg\:mt-12 {
    margin-top: 3rem;
  }

  .lg\:mt-24 {
    margin-top: 6rem;
  }

  .lg\:mt-96 {
    margin-top: 24rem;
  }

  .lg\:mt-\[440px\] {
    margin-top: 440px;
  }

  .lg\:block {
    display: block;
  }

  .lg\:inline {
    display: inline;
  }

  .lg\:flex {
    display: flex;
  }

  .lg\:grid {
    display: grid;
  }

  .lg\:hidden {
    display: none;
  }

  .lg\:max-h-full {
    max-height: 100%;
  }

  .lg\:w-1\/2 {
    width: 50%;
  }

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

  .lg\:max-w-\[45ch\] {
    max-width: 45ch;
  }

  .lg\:flex-1 {
    flex: 1 1 0%;
  }

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

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

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

  .lg\:grid-cols-\[min-content_1fr\] {
    grid-template-columns: min-content 1fr;
  }

  .lg\:grid-cols-subgrid {
    grid-template-columns: subgrid;
  }

  .lg\:grid-rows-\[auto_auto_auto_auto\] {
    grid-template-rows: auto auto auto auto;
  }

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

  .lg\:items-start {
    align-items: flex-start;
  }

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

  .lg\:gap-0 {
    gap: 0px;
  }

  .lg\:gap-12 {
    gap: 3rem;
  }

  .lg\:gap-28 {
    gap: 7rem;
  }

  .lg\:gap-y-20 {
    row-gap: 5rem;
  }

  .lg\:justify-self-end {
    justify-self: end;
  }

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

  .lg\:border-b-0 {
    border-bottom-width: 0px;
  }

  .lg\:border-r {
    border-right-width: 1px;
  }

  .lg\:border-solid {
    border-style: solid;
  }

  .lg\:border-gray-300 {
    border-color: var(--color-gray-300);
  }

  .lg\:p-12 {
    padding: 3rem;
  }

  .lg\:p-8 {
    padding: 2rem;
  }

  .lg\:\!px-0 {
    padding-left: 0px !important;
    padding-right: 0px !important;
  }

  .lg\:px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .lg\:py-20 {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .lg\:py-\[5rem\] {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .lg\:py-\[7\.5rem\] {
    padding-top: 7.5rem;
    padding-bottom: 7.5rem;
  }

  .lg\:pb-\[5rem\] {
    padding-bottom: 5rem;
  }

  .lg\:pl-12 {
    padding-left: 3rem;
  }

  .lg\:pl-14 {
    padding-left: 3.5rem;
  }

  .lg\:pt-\[10rem\] {
    padding-top: 10rem;
  }

  .lg\:pt-\[3\.25rem\] {
    padding-top: 3.25rem;
  }

  .lg\:text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }
}

@media (min-width: 1172px) {
  .xl\:col-span-8 {
    grid-column: span 8 / span 8;
  }

  .xl\:block {
    display: block;
  }

  .xl\:gap-12 {
    gap: 3rem;
  }

  .xl\:p-12 {
    padding: 3rem;
  }

  .xl\:pb-\[286px\] {
    padding-bottom: 286px;
  }
}

.\[\&\>\*\]\:w-full>* {
  width: 100%;
}

@media (min-width: 780px) {
  .md\:\[\&\>\*\]\:w-auto>* {
    width: auto;
  }
}

.\[\&\>br\]\:hidden>br {
  display: none;
}

@media (min-width: 1024px) {
  .lg\:\[\&\>br\]\:block>br {
    display: block;
  }
}

.\[\&\>span\]\:bg-gradient-to-b>span {
  background-image: linear-gradient(to bottom, var(--tw-gradient-stops));
}

.\[\&\>span\]\:from-white>span {
  --tw-gradient-from: #fff var(--tw-gradient-from-position);
  --tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to);
}

.\[\&\>span\]\:to-white\/70>span {
  --tw-gradient-to: rgb(255 255 255 / 0.7) var(--tw-gradient-to-position);
}

.\[\&\>span\]\:bg-clip-text>span {
  -webkit-background-clip: text;
          background-clip: text;
}

.\[\&\>strong\]\:text-gray-800>strong {
  color: var(--color-gray-800);
}

.\[\&\>strong\]\:text-green-400>strong {
  color: var(--color-green-400);
}

.\[\&\>strong\]\:text-green-600>strong {
  color: var(--color-green-600);
}

.group[data-theme="dark"] .group-data-\[theme\=dark\]\:\[\&\>strong\]\:text-green-400>strong {
  color: var(--color-green-400);
}
