/*! tailwindcss v4.1.12 | MIT License | https://tailwindcss.com */
/*! modern-normalize v1.1.0 | MIT License | https://github.com/sindresorhus/modern-normalize */
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
/*!*/
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol',
    'Noto Color Emoji';
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New',
    monospace;
    --color-red-50: oklch(97.1% 0.013 17.38);
    --color-red-100: oklch(93.6% 0.032 17.717);
    --color-red-200: oklch(88.5% 0.062 18.334);
    --color-red-300: oklch(80.8% 0.114 19.571);
    --color-red-400: oklch(70.4% 0.191 22.216);
    --color-red-500: oklch(63.7% 0.237 25.331);
    --color-red-600: oklch(57.7% 0.245 27.325);
    --color-red-700: oklch(50.5% 0.213 27.518);
    --color-red-800: oklch(44.4% 0.177 26.899);
    --color-orange-50: oklch(98% 0.016 73.684);
    --color-orange-100: oklch(95.4% 0.038 75.164);
    --color-orange-200: oklch(90.1% 0.076 70.697);
    --color-orange-300: oklch(83.7% 0.128 66.29);
    --color-orange-500: oklch(70.5% 0.213 47.604);
    --color-orange-600: oklch(64.6% 0.222 41.116);
    --color-orange-700: oklch(55.3% 0.195 38.402);
    --color-orange-800: oklch(47% 0.157 37.304);
    --color-amber-50: oklch(98.7% 0.022 95.277);
    --color-amber-100: oklch(96.2% 0.059 95.617);
    --color-amber-200: oklch(92.4% 0.12 95.746);
    --color-amber-300: oklch(87.9% 0.169 91.605);
    --color-amber-400: oklch(82.8% 0.189 84.429);
    --color-amber-500: oklch(76.9% 0.188 70.08);
    --color-amber-600: oklch(66.6% 0.179 58.318);
    --color-amber-700: oklch(55.5% 0.163 48.998);
    --color-amber-800: oklch(47.3% 0.137 46.201);
    --color-yellow-50: oklch(98.7% 0.026 102.212);
    --color-yellow-100: oklch(97.3% 0.071 103.193);
    --color-yellow-200: oklch(94.5% 0.129 101.54);
    --color-yellow-400: oklch(85.2% 0.199 91.936);
    --color-yellow-500: oklch(79.5% 0.184 86.047);
    --color-yellow-600: oklch(68.1% 0.162 75.834);
    --color-yellow-700: oklch(55.4% 0.135 66.442);
    --color-yellow-800: oklch(47.6% 0.114 61.907);
    --color-yellow-900: oklch(42.1% 0.095 57.708);
    --color-lime-100: oklch(96.7% 0.067 122.328);
    --color-green-50: oklch(98.2% 0.018 155.826);
    --color-green-100: oklch(96.2% 0.044 156.743);
    --color-green-200: oklch(92.5% 0.084 155.995);
    --color-green-400: oklch(79.2% 0.209 151.711);
    --color-green-500: oklch(72.3% 0.219 149.579);
    --color-green-600: oklch(62.7% 0.194 149.214);
    --color-green-700: oklch(52.7% 0.154 150.069);
    --color-green-800: oklch(44.8% 0.119 151.328);
    --color-green-900: oklch(39.3% 0.095 152.535);
    --color-emerald-50: oklch(97.9% 0.021 166.113);
    --color-emerald-100: oklch(95% 0.052 163.051);
    --color-emerald-200: oklch(90.5% 0.093 164.15);
    --color-emerald-300: oklch(84.5% 0.143 164.978);
    --color-emerald-500: oklch(69.6% 0.17 162.48);
    --color-emerald-600: oklch(59.6% 0.145 163.225);
    --color-emerald-700: oklch(50.8% 0.118 165.612);
    --color-emerald-800: oklch(43.2% 0.095 166.913);
    --color-emerald-900: oklch(37.8% 0.077 168.94);
    --color-teal-50: oklch(98.4% 0.014 180.72);
    --color-teal-100: oklch(95.3% 0.051 180.801);
    --color-teal-200: oklch(91% 0.096 180.426);
    --color-teal-400: oklch(77.7% 0.152 181.912);
    --color-teal-500: oklch(70.4% 0.14 182.503);
    --color-teal-600: oklch(60% 0.118 184.704);
    --color-teal-700: oklch(51.1% 0.096 186.391);
    --color-teal-900: oklch(38.6% 0.063 188.416);
    --color-cyan-50: oklch(98.4% 0.019 200.873);
    --color-cyan-100: oklch(95.6% 0.045 203.388);
    --color-sky-100: oklch(95.1% 0.026 236.824);
    --color-blue-50: oklch(97% 0.014 254.604);
    --color-blue-100: oklch(93.2% 0.032 255.585);
    --color-blue-200: oklch(88.2% 0.059 254.128);
    --color-blue-300: oklch(80.9% 0.105 251.813);
    --color-blue-500: oklch(62.3% 0.214 259.815);
    --color-blue-600: oklch(54.6% 0.245 262.881);
    --color-blue-700: oklch(48.8% 0.243 264.376);
    --color-blue-800: oklch(42.4% 0.199 265.638);
    --color-blue-900: oklch(37.9% 0.146 265.522);
    --color-indigo-50: oklch(96.2% 0.018 272.314);
    --color-indigo-100: oklch(93% 0.034 272.788);
    --color-indigo-200: oklch(87% 0.065 274.039);
    --color-indigo-300: oklch(78.5% 0.115 274.713);
    --color-indigo-400: oklch(67.3% 0.182 276.935);
    --color-indigo-500: oklch(58.5% 0.233 277.117);
    --color-indigo-600: oklch(51.1% 0.262 276.966);
    --color-indigo-700: oklch(45.7% 0.24 277.023);
    --color-indigo-800: oklch(39.8% 0.195 277.366);
    --color-indigo-900: oklch(35.9% 0.144 278.697);
    --color-violet-50: oklch(96.9% 0.016 293.756);
    --color-violet-100: oklch(94.3% 0.029 294.588);
    --color-violet-600: oklch(54.1% 0.281 293.009);
    --color-purple-50: oklch(97.7% 0.014 308.299);
    --color-purple-100: oklch(94.6% 0.033 307.174);
    --color-purple-200: oklch(90.2% 0.063 306.703);
    --color-purple-400: oklch(71.4% 0.203 305.504);
    --color-purple-500: oklch(62.7% 0.265 303.9);
    --color-purple-600: oklch(55.8% 0.288 302.321);
    --color-purple-700: oklch(49.6% 0.265 301.924);
    --color-purple-800: oklch(43.8% 0.218 303.724);
    --color-pink-100: oklch(94.8% 0.028 342.258);
    --color-pink-200: oklch(89.9% 0.061 343.231);
    --color-pink-500: oklch(65.6% 0.241 354.308);
    --color-pink-600: oklch(59.2% 0.249 0.584);
    --color-pink-700: oklch(52.5% 0.223 3.958);
    --color-rose-100: oklch(94.1% 0.03 12.58);
    --color-slate-50: oklch(98.4% 0.003 247.858);
    --color-slate-200: oklch(92.9% 0.013 255.508);
    --color-slate-700: oklch(37.2% 0.044 257.287);
    --color-gray-50: oklch(98.5% 0.002 247.839);
    --color-gray-100: oklch(96.7% 0.003 264.542);
    --color-gray-200: oklch(92.8% 0.006 264.531);
    --color-gray-300: oklch(87.2% 0.01 258.338);
    --color-gray-400: oklch(70.7% 0.022 261.325);
    --color-gray-500: oklch(55.1% 0.027 264.364);
    --color-gray-600: oklch(44.6% 0.03 256.802);
    --color-gray-700: oklch(37.3% 0.034 259.733);
    --color-gray-800: oklch(27.8% 0.033 256.848);
    --color-gray-900: oklch(21% 0.034 264.665);
    --color-neutral-50: oklch(98.5% 0 0);
    --color-neutral-100: oklch(97% 0 0);
    --color-black: #000;
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-xs: 20rem;
    --container-sm: 24rem;
    --container-md: 28rem;
    --container-lg: 32rem;
    --container-xl: 36rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --container-5xl: 64rem;
    --container-6xl: 72rem;
    --container-7xl: 80rem;
    --text-xs: 0.75rem;
    --text-xs--line-height: calc(1 / 0.75);
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --text-7xl: 4.5rem;
    --text-7xl--line-height: 1;
    --text-9xl: 8rem;
    --text-9xl--line-height: 1;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;
    --font-weight-black: 900;
    --tracking-tight: -0.025em;
    --tracking-wide: 0.025em;
    --tracking-wider: 0.05em;
    --tracking-widest: 0.1em;
    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-relaxed: 1.625;
    --radius-sm: 0.25rem;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --radius-2xl: 1rem;
    --radius-3xl: 1.5rem;
    --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --animate-spin: spin 1s linear infinite;
    --animate-ping: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
    --animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
    --animate-bounce: bounce 1s infinite;
    --blur-sm: 8px;
    --blur-md: 12px;
    --blur-xl: 24px;
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-manifest-primary: #4F46E5;
    --color-manifest-primary-dark: #4338CA;
    --color-manifest-primary-light: #EEF2FF;
    --color-manifest-primary-border: #DDD6FE;
    --color-manifest-secondary: #7C3AED;
    --color-manifest-secondary-light: #F3E8FF;
    --color-manifest-accent: #6366F1;
    --color-manifest-accent-light: #E0E7FF;
    --color-manifest-text: #2D2926;
    --color-manifest-text-muted: #6B6560;
    --color-manifest-border: #E8E4E0;
    --color-manifest-border-strong: #CDC8C3;
    --color-manifest-bg: #FDFCFB;
    --color-manifest-card: #FFFFFF;
    --color-manifest-success: #34C759;
    --color-manifest-success-dark: #16A34A;
    --color-manifest-success-light: #DCFCE7;
    --color-manifest-warning: #FF9500;
    --color-manifest-warning-dark: #EAB308;
    --color-manifest-warning-light: #FEF9C3;
    --color-manifest-danger: #DC2626;
    --color-manifest-danger-light: #FEE2E2;
    --color-manifest-danger-lighter: #FEF2F2;
    --color-manifest-danger-border: #FECACA;
    --color-manifest-info: #2563EB;
    --color-manifest-info-light: #DBEAFE;
    --color-manifest-cat-sale: #059669;
    --color-manifest-cat-sale-bg: #ECFDF5;
    --color-manifest-cat-services: #7C3AED;
    --color-manifest-cat-services-bg: #F5F3FF;
    --color-manifest-cat-jobs: #C2410C;
    --color-manifest-cat-jobs-bg: #FFF7ED;
    --color-manifest-cat-events: #BE123C;
    --color-manifest-cat-events-bg: #FFF1F2;
    --color-manifest-cat-housing: #1D4ED8;
    --color-manifest-cat-housing-bg: #EFF6FF;
    --color-manifest-cat-warning: #D97706;
    --color-manifest-cat-dark: #1A1A1A;
    --color-manifest-bg-muted: #F5F2EF;
    --color-manifest-text-light: #8C857E;
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji');
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type='button'], [type='reset'], [type='submit']), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden='until-found'])) {
    display: none !important;
  }
}
@layer utilities {
  .diff {
    position: relative;
    display: grid;
    width: 100%;
    overflow: hidden;
    webkit-user-select: none;
    user-select: none;
    direction: ltr;
    container-type: inline-size;
    grid-template-columns: auto 1fr;
    &:focus-visible, &:has(.diff-item-1:focus) {
      outline-style: var(--tw-outline-style);
      outline-width: 2px;
      outline-offset: 1px;
      outline-color: var(--color-base-content);
    }
    &:focus-visible {
      outline-style: var(--tw-outline-style);
      outline-width: 2px;
      outline-offset: 1px;
      outline-color: var(--color-base-content);
      .diff-resizer {
        min-width: 90cqi;
        max-width: 90cqi;
      }
    }
    &:has(.diff-item-2:focus-visible) {
      outline-style: var(--tw-outline-style);
      outline-width: 2px;
      outline-offset: 1px;
      .diff-resizer {
        min-width: 10cqi;
        max-width: 10cqi;
      }
    }
    @supports (-webkit-overflow-scrolling: touch) and (overflow: -webkit-paged-x) {
      &:focus {
        .diff-resizer {
          min-width: 10cqi;
          max-width: 10cqi;
        }
      }
      &:has(.diff-item-1:focus) {
        .diff-resizer {
          min-width: 90cqi;
          max-width: 90cqi;
        }
      }
    }
  }
  .modal {
    pointer-events: none;
    visibility: hidden;
    position: fixed;
    inset: calc(0.25rem * 0);
    margin: calc(0.25rem * 0);
    display: grid;
    height: 100%;
    max-height: none;
    width: 100%;
    max-width: none;
    align-items: center;
    justify-items: center;
    background-color: transparent;
    padding: calc(0.25rem * 0);
    color: inherit;
    overflow-x: hidden;
    transition: transform 0.3s ease-out, visibility 0.3s allow-discrete, background-color 0.3s ease-out, opacity 0.1s ease-out;
    overflow-y: hidden;
    overscroll-behavior: contain;
    z-index: 999;
    &::backdrop {
      display: none;
    }
    &.modal-open, &[open], &:target {
      background-color: oklch(0% 0 0/ 0.4);
      transition: transform 0.3s ease-out, background-color 0.3s ease-out, opacity 0.1s ease-out;
      pointer-events: auto;
      visibility: visible;
      opacity: 100%;
      .modal-box {
        translate: 0 0;
        scale: 1;
        opacity: 1;
      }
    }
    @starting-style {
      &.modal-open, &[open], &:target {
        visibility: hidden;
        opacity: 0%;
      }
    }
  }
  .drawer-side {
    pointer-events: none;
    visibility: hidden;
    position: fixed;
    inset-inline-start: calc(0.25rem * 0);
    top: calc(0.25rem * 0);
    grid-column-start: 1;
    grid-row-start: 1;
    display: grid;
    width: 100%;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    grid-template-rows: repeat(1, minmax(0, 1fr));
    align-items: flex-start;
    justify-items: start;
    overflow-x: hidden;
    overflow-y: hidden;
    overscroll-behavior: contain;
    opacity: 0%;
    transition: opacity 0.2s ease-out 0.1s allow-discrete, visibility 0.3s ease-out 0.1s allow-discrete;
    height: 100vh;
    height: 100dvh;
    > .drawer-overlay {
      position: sticky;
      top: calc(0.25rem * 0);
      cursor: pointer;
      place-self: stretch;
      background-color: oklch(0% 0 0 / 40%);
    }
    > * {
      grid-column-start: 1;
      grid-row-start: 1;
    }
    > *:not(.drawer-overlay) {
      will-change: transform;
      transition: translate 0.3s ease-out;
      translate: -100%;
      [dir="rtl"] & {
        translate: 100%;
      }
    }
  }
  .drawer-open {
    > .drawer-side {
      overflow-y: auto;
    }
    > .drawer-toggle {
      display: none;
      & ~ .drawer-side {
        pointer-events: auto;
        visibility: visible;
        position: sticky;
        display: block;
        width: auto;
        overscroll-behavior: auto;
        opacity: 100%;
        & > .drawer-overlay {
          cursor: default;
          background-color: transparent;
        }
        & > *:not(.drawer-overlay) {
          translate: 0%;
          [dir="rtl"] & {
            translate: 0%;
          }
        }
      }
      &:checked ~ .drawer-side {
        pointer-events: auto;
        visibility: visible;
      }
    }
  }
  .modal-toggle {
    position: fixed;
    height: calc(0.25rem * 0);
    width: calc(0.25rem * 0);
    appearance: none;
    opacity: 0%;
    &:checked + .modal {
      pointer-events: auto;
      visibility: visible;
      opacity: 100%;
      background-color: oklch(0% 0 0/ 0.4);
      .modal-box {
        translate: 0 0;
        scale: 1;
        opacity: 1;
      }
    }
    @starting-style {
      &:checked + .modal {
        visibility: hidden;
        opacity: 0%;
      }
    }
  }
  .drawer-toggle {
    position: fixed;
    height: calc(0.25rem * 0);
    width: calc(0.25rem * 0);
    appearance: none;
    opacity: 0%;
    &:checked {
      & ~ .drawer-side {
        pointer-events: auto;
        visibility: visible;
        overflow-y: auto;
        opacity: 100%;
        & > *:not(.drawer-overlay) {
          translate: 0%;
        }
      }
    }
    &:focus-visible ~ .drawer-content label.drawer-button {
      outline: 2px solid;
      outline-offset: 2px;
    }
  }
  .tooltip {
    position: relative;
    display: inline-block;
    --tt-bg: var(--color-neutral);
    --tt-off: calc(100% + 0.5rem);
    --tt-tail: calc(100% + 1px + 0.25rem);
    > :where(.tooltip-content), &[data-tip]:before {
      position: absolute;
      max-width: 20rem;
      border-radius: var(--radius-field);
      padding-inline: calc(0.25rem * 2);
      padding-block: calc(0.25rem * 1);
      text-align: center;
      white-space: normal;
      color: var(--color-neutral-content);
      opacity: 0%;
      font-size: 0.875rem;
      line-height: 1.25em;
      transition: opacity 0.2s cubic-bezier(0.4, 0, 0.2, 1) 75ms, transform 0.2s cubic-bezier(0.4, 0, 0.2, 1) 75ms;
      background-color: var(--tt-bg);
      width: max-content;
      pointer-events: none;
      z-index: 1;
      --tw-content: attr(data-tip);
      content: var(--tw-content);
    }
    &:after {
      position: absolute;
      position: absolute;
      opacity: 0%;
      background-color: var(--tt-bg);
      transition: opacity 0.2s cubic-bezier(0.4, 0, 0.2, 1) 75ms, transform 0.2s cubic-bezier(0.4, 0, 0.2, 1) 75ms;
      content: "";
      pointer-events: none;
      width: 0.625rem;
      height: 0.25rem;
      display: block;
      mask-repeat: no-repeat;
      mask-position: -1px 0;
      --mask-tooltip: url("data:image/svg+xml,%3Csvg width='10' height='4' viewBox='0 0 8 4' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0.500009 1C3.5 1 3.00001 4 5.00001 4C7 4 6.5 1 9.5 1C10 1 10 0.499897 10 0H0C-1.99338e-08 0.5 0 1 0.500009 1Z' fill='black'/%3E%3C/svg%3E%0A");
      mask-image: var(--mask-tooltip);
    }
    &.tooltip-open, &[data-tip]:hover, &:hover, &:has(:focus-visible) {
      > .tooltip-content, &[data-tip]:before, &:after {
        opacity: 100%;
        --tt-pos: 0rem;
        transition: opacity 0.2s cubic-bezier(0.4, 0, 0.2, 1) 0s, transform 0.2s cubic-bezier(0.4, 0, 0.2, 1) 0ms;
      }
    }
    > .tooltip-content, &[data-tip]:before {
      transform: translateX(-50%) translateY(var(--tt-pos, 0.25rem));
      inset: auto auto var(--tt-off) 50%;
    }
    &:after {
      transform: translateX(-50%) translateY(var(--tt-pos, 0.25rem));
      inset: auto auto var(--tt-tail) 50%;
    }
  }
  .tab {
    position: relative;
    display: inline-flex;
    cursor: pointer;
    appearance: none;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    text-align: center;
    webkit-user-select: none;
    user-select: none;
    &:hover {
      @media (hover: hover) {
        color: var(--color-base-content);
      }
    }
    --tab-p: 1rem;
    --tab-bg: var(--color-base-100);
    --tab-border-color: var(--color-base-300);
    --tab-radius-ss: 0;
    --tab-radius-se: 0;
    --tab-radius-es: 0;
    --tab-radius-ee: 0;
    --tab-order: 0;
    --tab-radius-min: calc(0.75rem - var(--border));
    border-color: #0000;
    order: var(--tab-order);
    height: calc(var(--size-field, 0.25rem) * 10);
    font-size: 0.875rem;
    padding-inline-start: var(--tab-p);
    padding-inline-end: var(--tab-p);
    &:is(input[type="radio"]) {
      min-width: fit-content;
      &:after {
        content: attr(aria-label);
      }
    }
    &:is(label) {
      position: relative;
      input {
        position: absolute;
        inset: calc(0.25rem * 0);
        cursor: pointer;
        appearance: none;
        opacity: 0%;
      }
    }
    &:checked, &:is(label:has(:checked)), &:is(.tab-active, [aria-selected="true"]) {
      & + .tab-content {
        display: block;
        height: 100%;
      }
    }
    &:not(:checked, label:has(:checked), :hover, .tab-active, [aria-selected="true"]) {
      color: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-base-content) 50%, transparent);
      }
    }
    &:not(input):empty {
      flex-grow: 1;
      cursor: default;
    }
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
      @media (forced-colors: active) {
        outline: 2px solid transparent;
        outline-offset: 2px;
      }
    }
    &:focus-visible, &:is(label:has(:checked:focus-visible)) {
      outline: 2px solid currentColor;
      outline-offset: -5px;
    }
    &[disabled] {
      pointer-events: none;
      opacity: 40%;
    }
  }
  .menu {
    display: flex;
    width: fit-content;
    flex-direction: column;
    flex-wrap: wrap;
    padding: calc(0.25rem * 2);
    --menu-active-fg: var(--color-neutral-content);
    --menu-active-bg: var(--color-neutral);
    font-size: 0.875rem;
    :where(li ul) {
      position: relative;
      margin-inline-start: calc(0.25rem * 4);
      padding-inline-start: calc(0.25rem * 2);
      white-space: nowrap;
      &:before {
        position: absolute;
        inset-inline-start: calc(0.25rem * 0);
        top: calc(0.25rem * 3);
        bottom: calc(0.25rem * 3);
        background-color: var(--color-base-content);
        opacity: 10%;
        width: var(--border);
        content: "";
      }
    }
    :where(li > .menu-dropdown:not(.menu-dropdown-show)) {
      display: none;
    }
    :where(li:not(.menu-title) > *:not(ul, details, .menu-title, .btn)), :where(li:not(.menu-title) > details > summary:not(.menu-title)) {
      display: grid;
      grid-auto-flow: column;
      align-content: flex-start;
      align-items: center;
      gap: calc(0.25rem * 2);
      border-radius: var(--radius-field);
      padding-inline: calc(0.25rem * 3);
      padding-block: calc(0.25rem * 1.5);
      text-align: start;
      transition-property: color, background-color, box-shadow;
      transition-duration: 0.2s;
      transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
      grid-auto-columns: minmax(auto, max-content) auto max-content;
      text-wrap: balance;
      user-select: none;
    }
    :where(li > details > summary) {
      --tw-outline-style: none;
      outline-style: none;
      @media (forced-colors: active) {
        outline: 2px solid transparent;
        outline-offset: 2px;
      }
      &::-webkit-details-marker {
        display: none;
      }
    }
    :where(li > details > summary), :where(li > .menu-dropdown-toggle) {
      &:after {
        justify-self: flex-end;
        display: block;
        height: 0.375rem;
        width: 0.375rem;
        rotate: -135deg;
        translate: 0 -1px;
        transition-property: rotate, translate;
        transition-duration: 0.2s;
        content: "";
        transform-origin: 50% 50%;
        box-shadow: 2px 2px inset;
        pointer-events: none;
      }
    }
    :where(li > details[open] > summary):after, :where(li > .menu-dropdown-toggle.menu-dropdown-show):after {
      rotate: 45deg;
      translate: 0 1px;
    }
    :where( li:not(.menu-title, .disabled) > *:not(ul, details, .menu-title), li:not(.menu-title, .disabled) > details > summary:not(.menu-title) ):not(.menu-active, :active, .btn) {
      &.menu-focus, &:focus-visible {
        cursor: pointer;
        background-color: var(--color-base-content);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
        }
        color: var(--color-base-content);
        --tw-outline-style: none;
        outline-style: none;
        @media (forced-colors: active) {
          outline: 2px solid transparent;
          outline-offset: 2px;
        }
      }
    }
    :where( li:not(.menu-title, .disabled) > *:not(ul, details, .menu-title):not(.menu-active, :active, .btn):hover, li:not(.menu-title, .disabled) > details > summary:not(.menu-title):not(.menu-active, :active, .btn):hover ) {
      cursor: pointer;
      background-color: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
      }
      --tw-outline-style: none;
      outline-style: none;
      @media (forced-colors: active) {
        outline: 2px solid transparent;
        outline-offset: 2px;
      }
      box-shadow: 0 1px oklch(0% 0 0 / 0.01) inset, 0 -1px oklch(100% 0 0 / 0.01) inset;
    }
    :where(li:empty) {
      background-color: var(--color-base-content);
      opacity: 10%;
      margin: 0.5rem 1rem;
      height: 1px;
    }
    :where(li) {
      position: relative;
      display: flex;
      flex-shrink: 0;
      flex-direction: column;
      flex-wrap: wrap;
      align-items: stretch;
      .badge {
        justify-self: flex-end;
      }
      & > *:not(ul, .menu-title, details, .btn):active, & > *:not(ul, .menu-title, details, .btn).menu-active, & > details > summary:active {
        --tw-outline-style: none;
        outline-style: none;
        @media (forced-colors: active) {
          outline: 2px solid transparent;
          outline-offset: 2px;
        }
        color: var(--menu-active-fg);
        background-color: var(--menu-active-bg);
        background-size: auto, calc(var(--noise) * 100%);
        background-image: none, var(--fx-noise);
        &:not(&:active) {
          box-shadow: 0 2px calc(var(--depth) * 3px) -2px var(--menu-active-bg);
        }
      }
      &.menu-disabled {
        pointer-events: none;
        color: var(--color-base-content);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
        }
      }
    }
    .dropdown:focus-within {
      .menu-dropdown-toggle:after {
        rotate: 45deg;
        translate: 0 1px;
      }
    }
    .dropdown-content {
      margin-top: calc(0.25rem * 2);
      padding: calc(0.25rem * 2);
      &:before {
        display: none;
      }
    }
  }
  .floating-label {
    position: relative;
    display: block;
    input {
      display: block;
      &::placeholder {
        transition: top 0.1s ease-out, translate 0.1s ease-out, scale 0.1s ease-out, opacity 0.1s ease-out;
      }
    }
    textarea {
      &::placeholder {
        transition: top 0.1s ease-out, translate 0.1s ease-out, scale 0.1s ease-out, opacity 0.1s ease-out;
      }
    }
    > span {
      position: absolute;
      inset-inline-start: calc(0.25rem * 3);
      z-index: 1;
      background-color: var(--color-base-100);
      padding-inline: calc(0.25rem * 1);
      opacity: 0%;
      font-size: 0.875rem;
      top: calc(var(--size-field, 0.25rem) * 10 / 2);
      line-height: 1;
      border-radius: 2px;
      pointer-events: none;
      translate: 0 -50%;
      transition: top 0.1s ease-out, translate 0.1s ease-out, scale 0.1s ease-out, opacity 0.1s ease-out;
    }
    &:focus-within, &:not(:has(input:placeholder-shown, textarea:placeholder-shown)) {
      ::placeholder {
        opacity: 0%;
        top: 0;
        translate: -12.5% calc(-50% - 0.125em);
        scale: 0.75;
        pointer-events: auto;
      }
      > span {
        opacity: 100%;
        top: 0;
        translate: -12.5% calc(-50% - 0.125em);
        scale: 0.75;
        pointer-events: auto;
      }
    }
    &:has(:disabled, [disabled]) {
      > span {
        opacity: 0%;
      }
    }
    &:has(.input-xs, .select-xs, .textarea-xs) span {
      font-size: 0.6875rem;
      top: calc(var(--size-field, 0.25rem) * 6 / 2);
    }
    &:has(.input-sm, .select-sm, .textarea-sm) span {
      font-size: 0.75rem;
      top: calc(var(--size-field, 0.25rem) * 8 / 2);
    }
    &:has(.input-md, .select-md, .textarea-md) span {
      font-size: 0.875rem;
      top: calc(var(--size-field, 0.25rem) * 10 / 2);
    }
    &:has(.input-lg, .select-lg, .textarea-lg) span {
      font-size: 1.125rem;
      top: calc(var(--size-field, 0.25rem) * 12 / 2);
    }
    &:has(.input-xl, .select-xl, .textarea-xl) span {
      font-size: 1.375rem;
      top: calc(var(--size-field, 0.25rem) * 14 / 2);
    }
  }
  .collapse-arrow {
    > .collapse-title:after {
      position: absolute;
      display: block;
      height: 0.5rem;
      width: 0.5rem;
      transform: translateY(-100%) rotate(45deg);
      transition-property: all;
      transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
      transition-duration: 0.2s;
      top: 1.9rem;
      inset-inline-end: 1.4rem;
      content: "";
      transform-origin: 75% 75%;
      box-shadow: 2px 2px;
      pointer-events: none;
    }
  }
  .collapse-plus {
    > .collapse-title:after {
      position: absolute;
      display: block;
      height: 0.5rem;
      width: 0.5rem;
      transition-property: all;
      transition-duration: 300ms;
      transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
      top: 0.9rem;
      inset-inline-end: 1.4rem;
      content: "+";
      pointer-events: none;
    }
  }
  .diff-item-2 {
    position: relative;
    grid-column-start: 1;
    grid-row-start: 1;
    &:after {
      pointer-events: none;
      position: absolute;
      top: calc(1/2 * 100%);
      right: 1px;
      bottom: calc(0.25rem * 0);
      z-index: 2;
      border-radius: calc(infinity * 1px);
      background-color: var(--color-base-100);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-base-100) 50%, transparent);
      }
      width: 1.2rem;
      height: 1.8rem;
      border: 2px solid var(--color-base-100);
      content: "";
      outline: 1px solid var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        outline: 1px solid color-mix(in oklab, var(--color-base-content) 5%, #0000);
      }
      outline-offset: -3px;
      backdrop-filter: blur(8px);
      box-shadow: 0 1px 2px 0 oklch(0% 0 0 / 0.1);
      translate: 50% -50%;
    }
    > * {
      pointer-events: none;
      position: absolute;
      top: calc(0.25rem * 0);
      bottom: calc(0.25rem * 0);
      left: calc(0.25rem * 0);
      height: 100%;
      width: 100cqi;
      max-width: none;
      object-fit: cover;
      object-position: center;
    }
    @supports (-webkit-overflow-scrolling: touch) and (overflow: -webkit-paged-x) {
      &:after {
        content: none;
      }
    }
  }
  .pika-single {
    &:is(div) {
      user-select: none;
      font-size: 0.75rem;
      z-index: 999;
      display: inline-block;
      position: relative;
      color: var(--color-base-content);
      background-color: var(--color-base-100);
      border-radius: var(--radius-box);
      border: var(--border) solid var(--color-base-200);
      padding: 0.5rem;
      &:before, &:after {
        content: "";
        display: table;
      }
      &:after {
        clear: both;
      }
      &.is-hidden {
        display: none;
      }
      &.is-bound {
        position: absolute;
      }
      .pika-lendar {
        css-float: left;
      }
      .pika-title {
        position: relative;
        text-align: center;
        select {
          cursor: pointer;
          position: absolute;
          z-index: 999;
          margin: 0;
          left: 0;
          top: 5px;
          opacity: 0;
        }
      }
      .pika-label {
        display: inline-block;
        position: relative;
        z-index: 999;
        overflow: hidden;
        margin: 0;
        padding: 5px 3px;
        background-color: var(--color-base-100);
      }
      .pika-prev, .pika-next {
        display: block;
        cursor: pointer;
        position: absolute;
        top: 0;
        outline: none;
        border: 0;
        width: 2.25rem;
        height: 2.25rem;
        color: #0000;
        font-size: 1.2em;
        border-radius: var(--radius-field);
        &:hover {
          background-color: var(--color-base-200);
        }
        &.is-disabled {
          cursor: default;
          opacity: 0.2;
        }
        &:before {
          display: inline-block;
          width: 2.25rem;
          height: 2.25rem;
          line-height: 2.25;
          color: var(--color-base-content);
        }
      }
      .pika-prev {
        left: 0;
        &:before {
          content: "‹";
        }
      }
      .pika-next {
        right: 0;
        &:before {
          content: "›";
        }
      }
      .pika-select {
        display: inline-block;
      }
      .pika-table {
        width: 100%;
        border-collapse: collapse;
        border-spacing: 0;
        border: 0;
        th, td {
          padding: 0;
        }
        th {
          opacity: 0.6;
          text-align: center;
          width: 2.25rem;
          height: 2.25rem;
        }
      }
      .pika-button {
        cursor: pointer;
        display: block;
        outline: none;
        border: 0;
        margin: 0;
        width: 2.25rem;
        height: 2.25rem;
        padding: 5px;
        text-align: right;
        text-align: center;
      }
      .pika-week {
        color: var(--color-base-content);
      }
      .is-today {
        .pika-button {
          background: var(--color-primary);
          color: var(--color-primary-content);
        }
      }
      .is-selected, .has-event {
        .pika-button {
          &, &:hover {
            color: var(--color-base-100);
            background-color: var(--color-base-content);
            border-radius: var(--radius-field);
          }
        }
      }
      .has-event {
        .pika-button {
          background: var(--color-base-primary);
        }
      }
      .is-disabled, .is-inrange {
        .pika-button {
          background: var(--color-base-primary);
        }
      }
      .is-startrange {
        .pika-button {
          color: var(--color-base-100);
          background: var(--color-base-content);
          border-radius: var(--radius-field);
        }
      }
      .is-endrange {
        .pika-button {
          color: var(--color-base-100);
          background: var(--color-base-content);
          border-radius: var(--radius-field);
        }
      }
      .is-disabled {
        .pika-button {
          pointer-events: none;
          cursor: default;
          color: var(--color-base-content);
          opacity: 0.3;
        }
      }
      .is-outside-current-month {
        .pika-button {
          color: var(--color-base-content);
          opacity: 0.3;
        }
      }
      .is-selection-disabled {
        pointer-events: none;
        cursor: default;
      }
      .pika-button:hover, .pika-row.pick-whole-week:hover .pika-button {
        color: var(--color-base-content);
        background-color: var(--color-base-200);
        border-radius: var(--radius-field);
      }
      .pika-table abbr {
        text-decoration: none;
        font-weight: normal;
      }
    }
  }
  .diff-item-1 {
    position: relative;
    z-index: 1;
    grid-column-start: 1;
    grid-row-start: 1;
    overflow: hidden;
    border-right: 2px solid var(--color-base-100);
    > * {
      pointer-events: none;
      position: absolute;
      top: calc(0.25rem * 0);
      bottom: calc(0.25rem * 0);
      left: calc(0.25rem * 0);
      height: 100%;
      width: 100cqi;
      max-width: none;
      object-fit: cover;
      object-position: center;
    }
  }
  .dock {
    position: fixed;
    right: calc(0.25rem * 0);
    bottom: calc(0.25rem * 0);
    left: calc(0.25rem * 0);
    z-index: 1;
    display: flex;
    width: 100%;
    flex-direction: row;
    align-items: center;
    justify-content: space-around;
    background-color: var(--color-base-100);
    padding: calc(0.25rem * 2);
    color: currentColor;
    border-top: 0.5px solid var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      border-top: 0.5px solid color-mix(in oklab, var(--color-base-content) 5%, #0000);
    }
    height: 4rem;
    height: calc(4rem + env(safe-area-inset-bottom));
    padding-bottom: env(safe-area-inset-bottom);
    > * {
      position: relative;
      margin-bottom: calc(0.25rem * 2);
      display: flex;
      height: 100%;
      max-width: calc(0.25rem * 32);
      flex-shrink: 1;
      flex-basis: 100%;
      cursor: pointer;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 1px;
      border-radius: var(--radius-box);
      background-color: transparent;
      transition: opacity 0.2s ease-out;
      &:where(.dock-active) {
        &:after {
          content: "";
          position: absolute;
          height: calc(0.25rem * 1);
          width: calc(0.25rem * 10);
          border-radius: calc(infinity * 1px);
          background-color: currentColor;
          bottom: 0.2rem;
          border-top: 3px solid;
        }
      }
      @media (hover: hover) {
        &:hover {
          opacity: 80%;
        }
      }
      &[aria-disabled="true"], &[disabled] {
        &, &:hover {
          pointer-events: none;
          color: var(--color-base-content);
          @supports (color: color-mix(in lab, red, red)) {
            color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
          }
          opacity: 100%;
        }
      }
      .dock-label {
        font-size: 0.6875rem;
      }
    }
  }
  .dropdown {
    position: relative;
    display: inline-block;
    position-area: var(--anchor-v, bottom) var(--anchor-h, span-right);
    & > *:not(summary):focus {
      --tw-outline-style: none;
      outline-style: none;
      @media (forced-colors: active) {
        outline: 2px solid transparent;
        outline-offset: 2px;
      }
    }
    .dropdown-content {
      position: absolute;
    }
    &:not(details, .dropdown-open, .dropdown-hover:hover, :focus-within) {
      .dropdown-content {
        display: none;
        transform-origin: top;
        opacity: 0%;
        scale: 95%;
      }
    }
    &[popover], .dropdown-content {
      z-index: 999;
      animation: dropdown 0.2s;
      transition-property: opacity, scale, display;
      transition-behavior: allow-discrete;
      transition-duration: 0.2s;
      transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    }
    @starting-style {
      &[popover], .dropdown-content {
        scale: 95%;
        opacity: 0;
      }
    }
    &.dropdown-open, &:not(.dropdown-hover):focus, &:focus-within {
      > [tabindex]:first-child {
        pointer-events: none;
      }
      .dropdown-content {
        opacity: 100%;
      }
    }
    &.dropdown-hover:hover {
      .dropdown-content {
        opacity: 100%;
        scale: 100%;
      }
    }
    &:is(details) {
      summary {
        &::-webkit-details-marker {
          display: none;
        }
      }
    }
    &.dropdown-open, &:focus, &:focus-within {
      .dropdown-content {
        scale: 100%;
      }
    }
    &:where([popover]) {
      background: #0000;
    }
    &[popover] {
      position: fixed;
      color: inherit;
      @supports not (position-area: bottom) {
        margin: auto;
        &.dropdown-open:not(:popover-open) {
          display: none;
          transform-origin: top;
          opacity: 0%;
          scale: 95%;
        }
        &::backdrop {
          background-color: color-mix(in oklab, #000 30%, #0000);
        }
      }
      &:not(.dropdown-open, :popover-open) {
        display: none;
        transform-origin: top;
        opacity: 0%;
        scale: 95%;
      }
    }
  }
  .btn {
    :where(&) {
      width: unset;
    }
    display: inline-flex;
    flex-shrink: 0;
    cursor: pointer;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    gap: calc(0.25rem * 1.5);
    text-align: center;
    vertical-align: middle;
    outline-offset: 2px;
    webkit-user-select: none;
    user-select: none;
    padding-inline: var(--btn-p);
    color: var(--btn-fg);
    --tw-prose-links: var(--btn-fg);
    height: var(--size);
    font-size: var(--fontsize, 0.875rem);
    font-weight: 600;
    outline-color: var(--btn-color, var(--color-base-content));
    transition-property: color, background-color, border-color, box-shadow;
    transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
    transition-duration: 0.2s;
    border-start-start-radius: var(--join-ss, var(--radius-field));
    border-start-end-radius: var(--join-se, var(--radius-field));
    border-end-start-radius: var(--join-es, var(--radius-field));
    border-end-end-radius: var(--join-ee, var(--radius-field));
    background-color: var(--btn-bg);
    background-size: auto, calc(var(--noise) * 100%);
    background-image: none, var(--btn-noise);
    border-width: var(--border);
    border-style: solid;
    border-color: var(--btn-border);
    text-shadow: 0 0.5px oklch(100% 0 0 / calc(var(--depth) * 0.15));
    box-shadow: 0 0.5px 0 0.5px oklch(100% 0 0 / calc(var(--depth) * 6%)) inset, var(--btn-shadow);
    --size: calc(var(--size-field, 0.25rem) * 10);
    --btn-bg: var(--btn-color, var(--color-base-200));
    --btn-fg: var(--color-base-content);
    --btn-p: 1rem;
    --btn-border: var(--btn-bg);
    @supports (color: color-mix(in lab, red, red)) {
      --btn-border: color-mix(in oklab, var(--btn-bg), #000 calc(var(--depth) * 5%));
    }
    --btn-shadow: 0 3px 2px -2px var(--btn-bg),
    0 4px 3px -2px var(--btn-bg);
    @supports (color: color-mix(in lab, red, red)) {
      --btn-shadow: 0 3px 2px -2px color-mix(in oklab, var(--btn-bg) calc(var(--depth) * 30%), #0000),
    0 4px 3px -2px color-mix(in oklab, var(--btn-bg) calc(var(--depth) * 30%), #0000);
    }
    --btn-noise: var(--fx-noise);
    .prose & {
      text-decoration-line: none;
    }
    @media (hover: hover) {
      &:hover {
        --btn-bg: var(--btn-color, var(--color-base-200));
        @supports (color: color-mix(in lab, red, red)) {
          --btn-bg: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 7%);
        }
      }
    }
    &:focus-visible {
      outline-width: 2px;
      outline-style: solid;
    }
    &:active:not(.btn-active) {
      translate: 0 0.5px;
      --btn-bg: var(--btn-color, var(--color-base-200));
      @supports (color: color-mix(in lab, red, red)) {
        --btn-bg: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 5%);
      }
      --btn-border: var(--btn-color, var(--color-base-200));
      @supports (color: color-mix(in lab, red, red)) {
        --btn-border: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 7%);
      }
      --btn-shadow: 0 0 0 0 oklch(0% 0 0/0), 0 0 0 0 oklch(0% 0 0/0);
    }
    &:is(:disabled, [disabled], .btn-disabled) {
      &:not(.btn-link, .btn-ghost) {
        background-color: var(--color-base-content);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
        }
        box-shadow: none;
      }
      pointer-events: none;
      --btn-border: #0000;
      --btn-noise: none;
      --btn-fg: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        --btn-fg: color-mix(in oklch, var(--color-base-content) 20%, #0000);
      }
      @media (hover: hover) {
        &:hover {
          pointer-events: none;
          background-color: var(--color-neutral);
          @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-neutral) 20%, transparent);
          }
          --btn-border: #0000;
          --btn-fg: var(--color-base-content);
          @supports (color: color-mix(in lab, red, red)) {
            --btn-fg: color-mix(in oklch, var(--color-base-content) 20%, #0000);
          }
        }
      }
    }
    &:is(input[type="checkbox"], input[type="radio"]) {
      appearance: none;
      &::after {
        content: attr(aria-label);
      }
    }
    &:where(input:checked:not(.filter .btn)) {
      --btn-color: var(--color-primary);
      --btn-fg: var(--color-primary-content);
      isolation: isolate;
    }
  }
  .loading {
    pointer-events: none;
    display: inline-block;
    aspect-ratio: 1 / 1;
    background-color: currentColor;
    vertical-align: middle;
    width: calc(var(--size-selector, 0.25rem) * 6);
    mask-size: 100%;
    mask-repeat: no-repeat;
    mask-position: center;
    mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' stroke='black' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg transform-origin='center'%3E%3Ccircle cx='12' cy='12' r='9.5' fill='none' stroke-width='3' stroke-linecap='round'%3E%3CanimateTransform attributeName='transform' type='rotate' from='0 12 12' to='360 12 12' dur='2s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dasharray' values='0,150;42,150;42,150' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dashoffset' values='0;-16;-59' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");
  }
  .tab-disabled {
    pointer-events: none;
    opacity: 40%;
  }
  .pointer-events-none {
    pointer-events: none;
  }
  .react-day-picker {
    user-select: none;
    background-color: var(--color-base-100);
    border-radius: var(--radius-box);
    border: var(--border) solid var(--color-base-200);
    font-size: 0.75rem;
    display: inline-block;
    position: relative;
    overflow: clip;
    &[dir="rtl"] {
      .rdp-nav {
        .rdp-chevron {
          transform-origin: 50%;
          transform: rotate(180deg);
        }
      }
    }
    * {
      box-sizing: border-box;
    }
    .rdp-day {
      width: 2.25rem;
      height: 2.25rem;
      text-align: center;
    }
    .rdp-day_button {
      cursor: pointer;
      font: inherit;
      color: inherit;
      width: 2.25rem;
      height: 2.25rem;
      border: 2px solid #0000;
      border-radius: var(--radius-field);
      background: 0 0;
      justify-content: center;
      align-items: center;
      margin: 0;
      padding: 0;
      display: flex;
      &:disabled {
        cursor: revert;
      }
      &:hover {
        background-color: var(--color-base-200);
      }
    }
    .rdp-caption_label {
      z-index: 1;
      white-space: nowrap;
      border: 0;
      align-items: center;
      display: inline-flex;
      position: relative;
    }
    .rdp-button_next {
      border-radius: var(--radius-field);
      &:hover {
        background-color: var(--color-base-200);
      }
    }
    .rdp-button_previous {
      border-radius: var(--radius-field);
      &:hover {
        background-color: var(--color-base-200);
      }
    }
    .rdp-button_next, .rdp-button_previous {
      cursor: pointer;
      font: inherit;
      color: inherit;
      appearance: none;
      width: 2.25rem;
      height: 2.25rem;
      background: 0 0;
      border: none;
      justify-content: center;
      align-items: center;
      margin: 0;
      padding: 0;
      display: inline-flex;
      position: relative;
      &:disabled {
        cursor: revert;
        opacity: 0.5;
      }
    }
    .rdp-chevron {
      fill: var(--color-base-content);
      width: 1rem;
      height: 1rem;
      display: inline-block;
    }
    .rdp-dropdowns {
      align-items: center;
      gap: 0.5rem;
      display: inline-flex;
      position: relative;
    }
    .rdp-dropdown {
      z-index: 2;
      opacity: 0;
      appearance: none;
      cursor: inherit;
      line-height: inherit;
      border: none;
      width: 100%;
      margin: 0;
      padding: 0;
      position: absolute;
      inset-block: 0;
      inset-inline-start: 0;
      &:focus-visible {
        ~ .rdp-caption_label {
          outline: 5px auto highlight;
          outline: 5px auto -webkit-focus-ring-color;
        }
      }
    }
    .rdp-dropdown_root {
      align-items: center;
      display: inline-flex;
      position: relative;
      &[data-disabled="true"] {
        .rdp-chevron {
          opacity: 0.5;
        }
      }
    }
    .rdp-month_caption {
      height: 2.75rem;
      font-size: 0.75rem;
      font-weight: inherit;
      place-content: center;
      display: flex;
    }
    .rdp-months {
      gap: 2rem;
      flex-wrap: wrap;
      max-width: fit-content;
      padding: 0.5rem;
      display: flex;
      position: relative;
    }
    .rdp-month_grid {
      border-collapse: collapse;
    }
    .rdp-nav {
      height: 2.75rem;
      inset-block-start: 0;
      inset-inline-end: 0;
      justify-content: space-between;
      align-items: center;
      width: 100%;
      padding-inline: 0.5rem;
      display: flex;
      position: absolute;
      top: 0.25rem;
    }
    .rdp-weekday {
      opacity: 0.6;
      padding: 0.5rem 0rem;
      text-align: center;
      font-size: smaller;
      font-weight: 500;
    }
    .rdp-week_number {
      opacity: 0.6;
      height: 2.25rem;
      width: 2.25rem;
      border: none;
      border-radius: 100%;
      text-align: center;
      font-size: small;
      font-weight: 400;
    }
    .rdp-today:not(.rdp-outside) {
      .rdp-day_button {
        background: var(--color-primary);
        color: var(--color-primary-content);
      }
    }
    .rdp-selected {
      font-weight: inherit;
      font-size: 0.75rem;
      .rdp-day_button {
        color: var(--color-base-100);
        background-color: var(--color-base-content);
        border-radius: var(--radius-field);
        border: none;
        &:hover {
          background-color: var(--color-base-content);
        }
      }
    }
    .rdp-outside {
      opacity: 0.75;
    }
    .rdp-disabled {
      opacity: 0.5;
    }
    .rdp-hidden {
      visibility: hidden;
      color: var(--color-base-content);
    }
    .rdp-range_start {
      .rdp-day_button {
        border-radius: var(--radius-field) 0 0 var(--radius-field);
      }
    }
    .rdp-range_start .rdp-day_button {
      background-color: var(--color-base-content);
      color: var(--color-base-content);
    }
    .rdp-range_middle {
      background-color: var(--color-base-200);
    }
    .rdp-range_middle .rdp-day_button {
      border: unset;
      border-radius: unset;
      color: inherit;
    }
    .rdp-range_end {
      color: var(--color-base-content);
      .rdp-day_button {
        border-radius: 0 var(--radius-field) var(--radius-field) 0;
      }
    }
    .rdp-range_end .rdp-day_button {
      color: var(--color-base-content);
      background-color: var(--color-base-content);
    }
    .rdp-range_start.rdp-range_end {
      background: revert;
    }
    .rdp-focusable {
      cursor: pointer;
    }
    .rdp-footer {
      border-top: var(--border) solid var(--color-base-200);
      padding: 0.5rem;
    }
  }
  .collapse {
    &:not(td, tr, colgroup) {
      visibility: visible;
    }
    position: relative;
    display: grid;
    overflow: hidden;
    border-radius: var(--radius-box, 1rem);
    width: 100%;
    grid-template-rows: max-content 0fr;
    transition: grid-template-rows 0.2s;
    > input:is([type="checkbox"], [type="radio"]) {
      grid-column-start: 1;
      grid-row-start: 1;
      appearance: none;
      opacity: 0;
      z-index: 1;
      width: 100%;
      padding: 1rem;
      padding-inline-end: 3rem;
      min-height: 3.75rem;
      transition: background-color 0.2s ease-out;
    }
    &:is([open], :focus:not(.collapse-close)), &:not(.collapse-close):has(> input:is([type="checkbox"], [type="radio"]):checked) {
      grid-template-rows: max-content 1fr;
    }
    &:is([open], :focus:not(.collapse-close)) > .collapse-content, &:not(.collapse-close) > :where(input:is([type="checkbox"], [type="radio"]):checked ~ .collapse-content) {
      visibility: visible;
      min-height: fit-content;
    }
    &:focus-visible, &:has(> input:is([type="checkbox"], [type="radio"]):focus-visible) {
      outline-color: var(--color-base-content);
      outline-style: solid;
      outline-width: 2px;
      outline-offset: 2px;
    }
    &:not(.collapse-close) {
      > input[type="checkbox"], > input[type="radio"]:not(:checked), > .collapse-title {
        cursor: pointer;
      }
    }
    &:focus:not(.collapse-close, .collapse[open]) > .collapse-title {
      cursor: unset;
    }
    &:is([open], :focus:not(.collapse-close)) > :where(.collapse-content), &:not(.collapse-close) > :where(input:is([type="checkbox"], [type="radio"]):checked ~ .collapse-content) {
      padding-bottom: 1rem;
      transition: padding 0.2s ease-out, background-color 0.2s ease-out;
    }
    &:is([open]) {
      &.collapse-arrow {
        > .collapse-title:after {
          transform: translateY(-50%) rotate(225deg);
        }
      }
    }
    &.collapse-open {
      &.collapse-arrow {
        > .collapse-title:after {
          transform: translateY(-50%) rotate(225deg);
        }
      }
      &.collapse-plus {
        > .collapse-title:after {
          content: "−";
        }
      }
    }
    &.collapse-arrow:focus:not(.collapse-close) {
      > .collapse-title:after {
        transform: translateY(-50%) rotate(225deg);
      }
    }
    &.collapse-arrow:not(.collapse-close) {
      > input:is([type="checkbox"], [type="radio"]):checked ~ .collapse-title:after {
        transform: translateY(-50%) rotate(225deg);
      }
    }
    &[open] {
      &.collapse-plus {
        > .collapse-title:after {
          content: "−";
        }
      }
    }
    &.collapse-plus:focus:not(.collapse-close) {
      > .collapse-title:after {
        content: "−";
      }
    }
    &.collapse-plus:not(.collapse-close) {
      > input:is([type="checkbox"], [type="radio"]):checked ~ .collapse-title:after {
        content: "−";
      }
    }
    &:is(details) {
      width: 100%;
      & summary {
        position: relative;
        display: block;
        &::-webkit-details-marker {
          display: none;
        }
      }
    }
    &:is(details) summary {
      outline: none;
    }
  }
  .collapse-content {
    grid-column-start: 1;
    grid-row-start: 1;
    visibility: hidden;
    grid-column-start: 1;
    grid-row-start: 2;
    min-height: 0;
    transition: visibility 0.2s;
    transition: padding 0.2s ease-out, background-color 0.2s ease-out;
    padding-left: 1rem;
    padding-right: 1rem;
    cursor: unset;
  }
  .validator {
    &:user-valid, &:has(:user-valid) {
      &, &:focus, &:checked, &[aria-checked="true"], &:focus-within {
        --input-color: var(--color-success);
      }
    }
    &:user-invalid, &:has(:user-invalid) {
      &, &:focus, &:checked, &[aria-checked="true"], &:focus-within {
        --input-color: var(--color-error);
      }
      & ~ .validator-hint {
        visibility: visible;
        display: block;
        color: var(--color-error);
      }
    }
    & ~ .validator-hint {
      visibility: hidden;
    }
  }
  .collapse-open {
    grid-template-rows: max-content 1fr;
    > .collapse-content {
      visibility: visible;
      min-height: fit-content;
      padding-bottom: 1rem;
      transition: padding 0.2sease-out, background-color 0.2sease-out;
    }
  }
  .collapse {
    visibility: collapse;
  }
  .invisible {
    visibility: hidden;
  }
  .visible {
    visibility: visible;
  }
  .tabs-lift {
    --tabs-height: auto;
    --tabs-direction: row;
    > .tab {
      --tab-border: 0 0 var(--border) 0;
      --tab-radius-ss: min(var(--radius-field), var(--tab-radius-min));
      --tab-radius-se: min(var(--radius-field), var(--tab-radius-min));
      --tab-radius-es: 0;
      --tab-radius-ee: 0;
      --tab-paddings: var(--border) var(--tab-p) 0 var(--tab-p);
      --tab-border-colors: #0000 #0000 var(--tab-border-color) #0000;
      --tab-corner-width: calc(100% + min(var(--radius-field), var(--tab-radius-min)) * 2);
      --tab-corner-height: min(var(--radius-field), var(--tab-radius-min));
      --tab-corner-position: top left, top right;
      border-width: var(--tab-border);
      border-start-start-radius: var(--tab-radius-ss);
      border-start-end-radius: var(--tab-radius-se);
      border-end-start-radius: var(--tab-radius-es);
      border-end-end-radius: var(--tab-radius-ee);
      padding: var(--tab-paddings);
      border-color: var(--tab-border-colors);
      &:is(.tab-active, [aria-selected="true"]):not(.tab-disabled, [disabled]), &:is(input:checked, label:has(:checked)) {
        --tab-border: var(--border) var(--border) 0 var(--border);
        --tab-border-colors: var(--tab-border-color) var(--tab-border-color) #0000
        var(--tab-border-color);
        --tab-paddings: 0 calc(var(--tab-p) - var(--border)) var(--border)
        calc(var(--tab-p) - var(--border));
        --tab-inset: auto auto 0 auto;
        --tab-grad: calc(69% - var(--border));
        --radius-start: radial-gradient(
        circle at top left,
        #0000 var(--tab-grad),
        var(--tab-border-color) calc(var(--tab-grad) + 0.25px),
        var(--tab-border-color) calc(var(--tab-grad) + var(--border)),
        var(--tab-bg) calc(var(--tab-grad) + var(--border) + 0.25px)
      );
        --radius-end: radial-gradient(
        circle at top right,
        #0000 var(--tab-grad),
        var(--tab-border-color) calc(var(--tab-grad) + 0.25px),
        var(--tab-border-color) calc(var(--tab-grad) + var(--border)),
        var(--tab-bg) calc(var(--tab-grad) + var(--border) + 0.25px)
      );
        background-color: var(--tab-bg);
        &:before {
          z-index: 1;
          content: "";
          display: block;
          position: absolute;
          width: var(--tab-corner-width);
          height: var(--tab-corner-height);
          background-position: var(--tab-corner-position);
          background-image: var(--radius-start), var(--radius-end);
          background-size: min(var(--radius-field), var(--tab-radius-min)) min(var(--radius-field), var(--tab-radius-min));
          background-repeat: no-repeat;
          inset: var(--tab-inset);
        }
        &:first-child:before {
          --radius-start: none;
        }
        [dir="rtl"] &:first-child:before {
          transform: rotateY(180deg);
        }
        &:last-child:before {
          --radius-end: none;
        }
        [dir="rtl"] &:last-child:before {
          transform: rotateY(180deg);
        }
      }
    }
    &:has(.tab-content) {
      > .tab:first-child {
        &:not(.tab-active, [aria-selected="true"]) {
          --tab-border-colors: var(--tab-border-color) var(--tab-border-color) #0000
          var(--tab-border-color);
        }
      }
    }
    .tab-content {
      --tabcontent-margin: calc(-1 * var(--border)) 0 0 0;
      --tabcontent-radius-ss: 0;
      --tabcontent-radius-se: var(--radius-box);
      --tabcontent-radius-es: var(--radius-box);
      --tabcontent-radius-ee: var(--radius-box);
    }
    :checked, label:has(:checked), :is(.tab-active, [aria-selected="true"]) {
      & + .tab-content {
        &:nth-child(1), &:nth-child(n + 3) {
          --tabcontent-radius-ss: var(--radius-box);
        }
      }
    }
  }
  .radial-progress {
    position: relative;
    display: inline-grid;
    height: var(--size);
    width: var(--size);
    place-content: center;
    border-radius: calc(infinity * 1px);
    background-color: transparent;
    vertical-align: middle;
    box-sizing: content-box;
    --value: 0;
    --size: 5rem;
    --thickness: calc(var(--size) / 10);
    --radialprogress: calc(var(--value) * 1%);
    transition: --radialprogress 0.3s linear;
    &:before {
      position: absolute;
      inset: calc(0.25rem * 0);
      border-radius: calc(infinity * 1px);
      content: "";
      background: radial-gradient(farthest-side, currentColor 98%, #0000) top/var(--thickness) var(--thickness) no-repeat, conic-gradient(currentColor var(--radialprogress), #0000 0);
      webkit-mask: radial-gradient( farthest-side, #0000 calc(100% - var(--thickness)), #000 calc(100% + 0.5px - var(--thickness)) );
      mask: radial-gradient( farthest-side, #0000 calc(100% - var(--thickness)), #000 calc(100% + 0.5px - var(--thickness)) );
    }
    &:after {
      position: absolute;
      border-radius: calc(infinity * 1px);
      background-color: currentColor;
      transition: transform 0.3s linear;
      content: "";
      inset: calc(50% - var(--thickness) / 2);
      transform: rotate(calc(var(--value) * 3.6deg - 90deg)) translate(calc(var(--size) / 2 - 50%));
    }
  }
  .list {
    display: flex;
    flex-direction: column;
    font-size: 0.875rem;
    :where(.list-row) {
      --list-grid-cols: minmax(0, auto) 1fr;
      position: relative;
      display: grid;
      grid-auto-flow: column;
      gap: calc(0.25rem * 4);
      border-radius: var(--radius-box);
      padding: calc(0.25rem * 4);
      word-break: break-word;
      grid-template-columns: var(--list-grid-cols);
      &:has(.list-col-grow:nth-child(1)) {
        --list-grid-cols: 1fr;
      }
      &:has(.list-col-grow:nth-child(2)) {
        --list-grid-cols: minmax(0, auto) 1fr;
      }
      &:has(.list-col-grow:nth-child(3)) {
        --list-grid-cols: minmax(0, auto) minmax(0, auto) 1fr;
      }
      &:has(.list-col-grow:nth-child(4)) {
        --list-grid-cols: minmax(0, auto) minmax(0, auto) minmax(0, auto) 1fr;
      }
      &:has(.list-col-grow:nth-child(5)) {
        --list-grid-cols: minmax(0, auto) minmax(0, auto) minmax(0, auto) minmax(0, auto) 1fr;
      }
      &:has(.list-col-grow:nth-child(6)) {
        --list-grid-cols: minmax(0, auto) minmax(0, auto) minmax(0, auto) minmax(0, auto)
        minmax(0, auto) 1fr;
      }
      :not(.list-col-wrap) {
        grid-row-start: 1;
      }
    }
    & > :not(:last-child) {
      &.list-row, .list-row {
        &:after {
          content: "";
          border-bottom: var(--border) solid;
          inset-inline: var(--radius-box);
          position: absolute;
          bottom: calc(0.25rem * 0);
          border-color: var(--color-base-content);
          @supports (color: color-mix(in lab, red, red)) {
            border-color: color-mix(in oklab, var(--color-base-content) 5%, transparent);
          }
        }
      }
    }
  }
  .toast {
    position: fixed;
    inset-inline-start: auto;
    inset-inline-end: calc(0.25rem * 0);
    top: auto;
    bottom: calc(0.25rem * 0);
    margin: calc(0.25rem * 4);
    display: flex;
    min-width: fit-content;
    flex-direction: column;
    gap: calc(0.25rem * 2);
    background-color: transparent;
    white-space: nowrap;
    translate: var(--toast-x, 0) var(--toast-y, 0);
    & > * {
      animation: toast 0.25s ease-out;
    }
    &:where(.toast-start) {
      inset-inline-start: calc(0.25rem * 0);
      inset-inline-end: auto;
      --toast-x: 0;
    }
    &:where(.toast-center) {
      inset-inline-start: calc(1/2 * 100%);
      inset-inline-end: calc(1/2 * 100%);
      --toast-x: -50%;
    }
    &:where(.toast-end) {
      inset-inline-start: auto;
      inset-inline-end: calc(0.25rem * 0);
      --toast-x: 0;
    }
    &:where(.toast-bottom) {
      top: auto;
      bottom: calc(0.25rem * 0);
      --toast-y: 0;
    }
    &:where(.toast-middle) {
      top: calc(1/2 * 100%);
      bottom: auto;
      --toast-y: -50%;
    }
    &:where(.toast-top) {
      top: calc(0.25rem * 0);
      bottom: auto;
      --toast-y: 0;
    }
  }
  .toggle {
    border: var(--border) solid currentColor;
    color: var(--input-color);
    position: relative;
    display: inline-grid;
    flex-shrink: 0;
    cursor: pointer;
    appearance: none;
    place-content: center;
    vertical-align: middle;
    webkit-user-select: none;
    user-select: none;
    grid-template-columns: 0fr 1fr 1fr;
    --radius-selector-max: calc(
    var(--radius-selector) + var(--radius-selector) + var(--radius-selector)
  );
    border-radius: calc( var(--radius-selector) + min(var(--toggle-p), var(--radius-selector-max)) + min(var(--border), var(--radius-selector-max)) );
    padding: var(--toggle-p);
    box-shadow: 0 1px currentColor inset;
    @supports (color: color-mix(in lab, red, red)) {
      box-shadow: 0 1px color-mix(in oklab, currentColor calc(var(--depth) * 10%), #0000) inset;
    }
    transition: color 0.3s, grid-template-columns 0.2s;
    --input-color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      --input-color: color-mix(in oklab, var(--color-base-content) 50%, #0000);
    }
    --toggle-p: 0.1875rem;
    --size: calc(var(--size-selector, 0.25rem) * 6);
    width: calc((var(--size) * 2) - (var(--border) + var(--toggle-p)) * 2);
    height: var(--size);
    > * {
      z-index: 1;
      grid-column: span 1 / span 1;
      grid-column-start: 2;
      grid-row-start: 1;
      height: 100%;
      cursor: pointer;
      appearance: none;
      background-color: transparent;
      padding: calc(0.25rem * 0.5);
      transition: opacity 0.2s, rotate 0.4s;
      border: none;
      &:focus {
        --tw-outline-style: none;
        outline-style: none;
        @media (forced-colors: active) {
          outline: 2px solid transparent;
          outline-offset: 2px;
        }
      }
      &:nth-child(2) {
        color: var(--color-base-100);
        rotate: 0deg;
      }
      &:nth-child(3) {
        color: var(--color-base-100);
        opacity: 0%;
        rotate: -15deg;
      }
    }
    &:has(:checked) {
      > :nth-child(2) {
        opacity: 0%;
        rotate: 15deg;
      }
      > :nth-child(3) {
        opacity: 100%;
        rotate: 0deg;
      }
    }
    &:before {
      position: relative;
      inset-inline-start: calc(0.25rem * 0);
      grid-column-start: 2;
      grid-row-start: 1;
      aspect-ratio: 1 / 1;
      height: 100%;
      border-radius: var(--radius-selector);
      background-color: currentColor;
      translate: 0;
      --tw-content: "";
      content: var(--tw-content);
      transition: background-color 0.1s, translate 0.2s, inset-inline-start 0.2s;
      box-shadow: 0 -1px oklch(0% 0 0 / calc(var(--depth) * 0.1)) inset, 0 8px 0 -4px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px currentColor;
      @supports (color: color-mix(in lab, red, red)) {
        box-shadow: 0 -1px oklch(0% 0 0 / calc(var(--depth) * 0.1)) inset, 0 8px 0 -4px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px color-mix(in oklab, currentColor calc(var(--depth) * 10%), #0000);
      }
      background-size: auto, calc(var(--noise) * 100%);
      background-image: none, var(--fx-noise);
    }
    @media (forced-colors: active) {
      &:before {
        outline-style: var(--tw-outline-style);
        outline-width: 1px;
        outline-offset: calc(1px * -1);
      }
    }
    @media print {
      &:before {
        outline: 0.25rem solid;
        outline-offset: -1rem;
      }
    }
    &:focus-visible, &:has(:focus-visible) {
      outline: 2px solid currentColor;
      outline-offset: 2px;
    }
    &:checked, &[aria-checked="true"], &:has(> input:checked) {
      grid-template-columns: 1fr 1fr 0fr;
      background-color: var(--color-base-100);
      --input-color: var(--color-base-content);
      &:before {
        background-color: currentColor;
      }
      @starting-style {
        &:before {
          opacity: 0;
        }
      }
    }
    &:indeterminate {
      grid-template-columns: 0.5fr 1fr 0.5fr;
    }
    &:disabled {
      cursor: not-allowed;
      opacity: 30%;
      &:before {
        background-color: transparent;
        border: var(--border) solid currentColor;
      }
    }
  }
  .input {
    cursor: text;
    border: var(--border) solid #0000;
    position: relative;
    display: inline-flex;
    flex-shrink: 1;
    appearance: none;
    align-items: center;
    gap: calc(0.25rem * 2);
    background-color: var(--color-base-100);
    padding-inline: calc(0.25rem * 3);
    vertical-align: middle;
    white-space: nowrap;
    width: clamp(3rem, 20rem, 100%);
    height: var(--size);
    font-size: 0.875rem;
    border-start-start-radius: var(--join-ss, var(--radius-field));
    border-start-end-radius: var(--join-se, var(--radius-field));
    border-end-start-radius: var(--join-es, var(--radius-field));
    border-end-end-radius: var(--join-ee, var(--radius-field));
    border-color: var(--input-color);
    box-shadow: 0 1px var(--input-color) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset;
    @supports (color: color-mix(in lab, red, red)) {
      box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset;
    }
    --size: calc(var(--size-field, 0.25rem) * 10);
    --input-color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      --input-color: color-mix(in oklab, var(--color-base-content) 20%, #0000);
    }
    &:where(input) {
      display: inline-flex;
    }
    :where(input) {
      display: inline-flex;
      height: 100%;
      width: 100%;
      appearance: none;
      background-color: transparent;
      border: none;
      &:focus, &:focus-within {
        --tw-outline-style: none;
        outline-style: none;
        @media (forced-colors: active) {
          outline: 2px solid transparent;
          outline-offset: 2px;
        }
      }
    }
    &:focus, &:focus-within {
      --input-color: var(--color-base-content);
      box-shadow: 0 1px var(--input-color);
      @supports (color: color-mix(in lab, red, red)) {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000);
      }
      outline: 2px solid var(--input-color);
      outline-offset: 2px;
      isolation: isolate;
    }
    &:has(> input[disabled]), &:is(:disabled, [disabled]) {
      cursor: not-allowed;
      border-color: var(--color-base-200);
      background-color: var(--color-base-200);
      color: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-base-content) 40%, transparent);
      }
      &::placeholder {
        color: var(--color-base-content);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
        }
      }
      box-shadow: none;
    }
    &:has(> input[disabled]) > input[disabled] {
      cursor: not-allowed;
    }
    &::-webkit-date-and-time-value {
      text-align: inherit;
    }
    &[type="number"] {
      &::-webkit-inner-spin-button {
        margin-block: calc(0.25rem * -3);
        margin-inline-end: calc(0.25rem * -3);
      }
    }
    &::-webkit-calendar-picker-indicator {
      position: absolute;
      inset-inline-end: 0.75em;
    }
  }
  .indicator {
    position: relative;
    display: inline-flex;
    width: max-content;
    :where(.indicator-item) {
      z-index: 1;
      position: absolute;
      white-space: nowrap;
      top: var(--inidicator-t, 0);
      bottom: var(--inidicator-b, auto);
      left: var(--inidicator-s, auto);
      right: var(--inidicator-e, 0);
      translate: var(--inidicator-x, 50%) var(--indicator-y, -50%);
    }
  }
  .table {
    font-size: 0.875rem;
    position: relative;
    width: 100%;
    border-radius: var(--radius-box);
    text-align: left;
    &:where(:dir(rtl), [dir="rtl"], [dir="rtl"] *) {
      text-align: right;
    }
    tr.row-hover {
      &, &:nth-child(even) {
        &:hover {
          @media (hover: hover) {
            background-color: var(--color-base-200);
          }
        }
      }
    }
    :where(th, td) {
      padding-inline: calc(0.25rem * 4);
      padding-block: calc(0.25rem * 3);
      vertical-align: middle;
    }
    :where(thead, tfoot) {
      white-space: nowrap;
      color: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-base-content) 60%, transparent);
      }
      font-size: 0.875rem;
      font-weight: 600;
    }
    :where(tfoot) {
      border-top: var(--border) solid var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        border-top: var(--border) solid color-mix(in oklch, var(--color-base-content) 5%, #0000);
      }
    }
    :where(.table-pin-rows thead tr) {
      position: sticky;
      top: calc(0.25rem * 0);
      z-index: 1;
      background-color: var(--color-base-100);
    }
    :where(.table-pin-rows tfoot tr) {
      position: sticky;
      bottom: calc(0.25rem * 0);
      z-index: 1;
      background-color: var(--color-base-100);
    }
    :where(.table-pin-cols tr th) {
      position: sticky;
      right: calc(0.25rem * 0);
      left: calc(0.25rem * 0);
      background-color: var(--color-base-100);
    }
    :where(thead tr, tbody tr:not(:last-child)) {
      border-bottom: var(--border) solid var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        border-bottom: var(--border) solid color-mix(in oklch, var(--color-base-content) 5%, #0000);
      }
    }
  }
  .avatar-offline {
    &:before {
      content: "";
      position: absolute;
      z-index: 1;
      display: block;
      border-radius: calc(infinity * 1px);
      background-color: var(--color-base-300);
      outline: 2px solid var(--color-base-100);
      width: 15%;
      height: 15%;
      top: 7%;
      right: 7%;
    }
  }
  .avatar-online {
    &:before {
      content: "";
      position: absolute;
      z-index: 1;
      display: block;
      border-radius: calc(infinity * 1px);
      background-color: var(--color-success);
      outline: 2px solid var(--color-base-100);
      width: 15%;
      height: 15%;
      top: 7%;
      right: 7%;
    }
  }
  .steps {
    display: inline-grid;
    grid-auto-flow: column;
    overflow: hidden;
    overflow-x: auto;
    counter-reset: step;
    grid-auto-columns: 1fr;
    .step {
      display: grid;
      grid-template-columns: repeat(1, minmax(0, 1fr));
      grid-template-columns: auto;
      grid-template-rows: repeat(2, minmax(0, 1fr));
      grid-template-rows: 40px 1fr;
      place-items: center;
      text-align: center;
      min-width: 4rem;
      --step-bg: var(--color-base-300);
      --step-fg: var(--color-base-content);
      &:before {
        top: calc(0.25rem * 0);
        grid-column-start: 1;
        grid-row-start: 1;
        height: calc(0.25rem * 2);
        width: 100%;
        border: 1px solid;
        color: var(--step-bg);
        background-color: var(--step-bg);
        --tw-content: "";
        content: var(--tw-content);
        margin-inline-start: -100%;
      }
      > .step-icon, &:not(:has(.step-icon)):after {
        content: counter(step);
        counter-increment: step;
        z-index: 1;
        color: var(--step-fg);
        background-color: var(--step-bg);
        border: 1px solid var(--step-bg);
        position: relative;
        grid-column-start: 1;
        grid-row-start: 1;
        display: grid;
        height: calc(0.25rem * 8);
        width: calc(0.25rem * 8);
        place-items: center;
        place-self: center;
        border-radius: calc(infinity * 1px);
      }
      &:first-child:before {
        content: none;
      }
      &[data-content]:after {
        content: attr(data-content);
      }
    }
    .step-neutral {
      + .step-neutral:before, &:after, > .step-icon {
        --step-bg: var(--color-neutral);
        --step-fg: var(--color-neutral-content);
      }
    }
    .step-primary {
      + .step-primary:before, &:after, > .step-icon {
        --step-bg: var(--color-primary);
        --step-fg: var(--color-primary-content);
      }
    }
    .step-secondary {
      + .step-secondary:before, &:after, > .step-icon {
        --step-bg: var(--color-secondary);
        --step-fg: var(--color-secondary-content);
      }
    }
    .step-accent {
      + .step-accent:before, &:after, > .step-icon {
        --step-bg: var(--color-accent);
        --step-fg: var(--color-accent-content);
      }
    }
    .step-info {
      + .step-info:before, &:after, > .step-icon {
        --step-bg: var(--color-info);
        --step-fg: var(--color-info-content);
      }
    }
    .step-success {
      + .step-success:before, &:after, > .step-icon {
        --step-bg: var(--color-success);
        --step-fg: var(--color-success-content);
      }
    }
    .step-warning {
      + .step-warning:before, &:after, > .step-icon {
        --step-bg: var(--color-warning);
        --step-fg: var(--color-warning-content);
      }
    }
    .step-error {
      + .step-error:before, &:after, > .step-icon {
        --step-bg: var(--color-error);
        --step-fg: var(--color-error-content);
      }
    }
  }
  .diff-resizer {
    position: relative;
    top: calc(1/2 * 100%);
    z-index: 1;
    grid-column-start: 1;
    grid-row-start: 1;
    height: calc(0.25rem * 2);
    width: 50cqi;
    max-width: calc(100cqi - 1rem);
    min-width: 1rem;
    resize: horizontal;
    overflow: hidden;
    opacity: 0%;
    transform: scaleY(3) translate(0.35rem, 0.08rem);
    cursor: ew-resize;
    transform-origin: 100% 100%;
    clip-path: inset(calc(100% - 0.75rem) 0 0 calc(100% - 0.75rem));
    transition: min-width 0.3s ease-out, max-width 0.3s ease-out;
  }
  .range {
    appearance: none;
    webkit-appearance: none;
    --range-thumb: var(--color-base-100);
    --range-thumb-size: calc(var(--size-selector, 0.25rem) * 6);
    --range-progress: currentColor;
    --range-fill: 1;
    --range-p: 0.25rem;
    --range-bg: currentColor;
    @supports (color: color-mix(in lab, red, red)) {
      --range-bg: color-mix(in oklab, currentColor 10%, #0000);
    }
    cursor: pointer;
    overflow: hidden;
    background-color: transparent;
    vertical-align: middle;
    width: clamp(3rem, 20rem, 100%);
    --radius-selector-max: calc(
    var(--radius-selector) + var(--radius-selector) + var(--radius-selector)
  );
    border-radius: calc(var(--radius-selector) + min(var(--range-p), var(--radius-selector-max)));
    border: none;
    height: var(--range-thumb-size);
    [dir="rtl"] & {
      --range-dir: -1;
    }
    &:focus {
      outline: none;
    }
    &:focus-visible {
      outline: 2px solid;
      outline-offset: 2px;
    }
    &::-webkit-slider-runnable-track {
      width: 100%;
      background-color: var(--range-bg);
      border-radius: var(--radius-selector);
      height: calc(var(--range-thumb-size) * 0.5);
    }
    @media (forced-colors: active) {
      &::-webkit-slider-runnable-track {
        border: 1px solid;
      }
    }
    @media (forced-colors: active) {
      &::-moz-range-track {
        border: 1px solid;
      }
    }
    &::-webkit-slider-thumb {
      position: relative;
      box-sizing: border-box;
      border-radius: calc(var(--radius-selector) + min(var(--range-p), var(--radius-selector-max)));
      background-color: currentColor;
      height: var(--range-thumb-size);
      width: var(--range-thumb-size);
      border: var(--range-p) solid;
      appearance: none;
      webkit-appearance: none;
      top: 50%;
      color: var(--range-progress);
      transform: translateY(-50%);
      box-shadow: 0 -1px oklch(0% 0 0 / calc(var(--depth) * 0.1)) inset, 0 8px 0 -4px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px currentColor, 0 0 0 2rem var(--range-thumb) inset, calc((var(--range-dir, 1) * -100rem) - (var(--range-dir, 1) * var(--range-thumb-size) / 2)) 0 0 calc(100rem * var(--range-fill));
      @supports (color: color-mix(in lab, red, red)) {
        box-shadow: 0 -1px oklch(0% 0 0 / calc(var(--depth) * 0.1)) inset, 0 8px 0 -4px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px color-mix(in oklab, currentColor calc(var(--depth) * 10%), #0000), 0 0 0 2rem var(--range-thumb) inset, calc((var(--range-dir, 1) * -100rem) - (var(--range-dir, 1) * var(--range-thumb-size) / 2)) 0 0 calc(100rem * var(--range-fill));
      }
    }
    &::-moz-range-track {
      width: 100%;
      background-color: var(--range-bg);
      border-radius: var(--radius-selector);
      height: calc(var(--range-thumb-size) * 0.5);
    }
    &::-moz-range-thumb {
      position: relative;
      box-sizing: border-box;
      border-radius: calc(var(--radius-selector) + min(var(--range-p), var(--radius-selector-max)));
      background-color: currentColor;
      height: var(--range-thumb-size);
      width: var(--range-thumb-size);
      border: var(--range-p) solid;
      top: 50%;
      color: var(--range-progress);
      box-shadow: 0 -1px oklch(0% 0 0 / calc(var(--depth) * 0.1)) inset, 0 8px 0 -4px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px currentColor, 0 0 0 2rem var(--range-thumb) inset, calc((var(--range-dir, 1) * -100rem) - (var(--range-dir, 1) * var(--range-thumb-size) / 2)) 0 0 calc(100rem * var(--range-fill));
      @supports (color: color-mix(in lab, red, red)) {
        box-shadow: 0 -1px oklch(0% 0 0 / calc(var(--depth) * 0.1)) inset, 0 8px 0 -4px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px color-mix(in oklab, currentColor calc(var(--depth) * 10%), #0000), 0 0 0 2rem var(--range-thumb) inset, calc((var(--range-dir, 1) * -100rem) - (var(--range-dir, 1) * var(--range-thumb-size) / 2)) 0 0 calc(100rem * var(--range-fill));
      }
    }
    &:disabled {
      cursor: not-allowed;
      opacity: 30%;
    }
  }
  .countdown {
    display: inline-flex;
    &.countdown {
      line-height: 1em;
    }
    & > * {
      display: inline-block;
      overflow-y: hidden;
      height: 1em;
      &:before {
        position: relative;
        content: "00\A 01\A 02\A 03\A 04\A 05\A 06\A 07\A 08\A 09\A 10\A 11\A 12\A 13\A 14\A 15\A 16\A 17\A 18\A 19\A 20\A 21\A 22\A 23\A 24\A 25\A 26\A 27\A 28\A 29\A 30\A 31\A 32\A 33\A 34\A 35\A 36\A 37\A 38\A 39\A 40\A 41\A 42\A 43\A 44\A 45\A 46\A 47\A 48\A 49\A 50\A 51\A 52\A 53\A 54\A 55\A 56\A 57\A 58\A 59\A 60\A 61\A 62\A 63\A 64\A 65\A 66\A 67\A 68\A 69\A 70\A 71\A 72\A 73\A 74\A 75\A 76\A 77\A 78\A 79\A 80\A 81\A 82\A 83\A 84\A 85\A 86\A 87\A 88\A 89\A 90\A 91\A 92\A 93\A 94\A 95\A 96\A 97\A 98\A 99\A";
        white-space: pre;
        top: calc(var(--value) * -1em);
        text-align: center;
        transition: all 1s cubic-bezier(1, 0, 0, 1);
      }
    }
  }
  .tabs-border {
    .tab {
      --tab-border-color: #0000 #0000 var(--tab-border-color) #0000;
      position: relative;
      border-radius: var(--radius-field);
      &:before {
        --tw-content: "";
        content: var(--tw-content);
        background-color: var(--tab-border-color);
        transition: background-color 0.2s ease;
        width: 80%;
        height: 3px;
        border-radius: var(--radius-field);
        bottom: 0;
        left: 10%;
        position: absolute;
      }
      &:is(.tab-active, [aria-selected="true"]):not(.tab-disabled, [disabled]), &:is(input:checked), &:is(label:has(:checked)) {
        &:before {
          --tab-border-color: currentColor;
          border-top: 3px solid;
        }
      }
    }
  }
  .chat-bubble {
    position: relative;
    display: block;
    width: fit-content;
    border-radius: var(--radius-field);
    background-color: var(--color-base-300);
    padding-inline: calc(0.25rem * 4);
    padding-block: calc(0.25rem * 2);
    color: var(--color-base-content);
    grid-row-end: 3;
    min-height: 2rem;
    min-width: 2.5rem;
    max-width: 90%;
    &:before {
      position: absolute;
      bottom: calc(0.25rem * 0);
      height: calc(0.25rem * 3);
      width: calc(0.25rem * 3);
      background-color: inherit;
      content: "";
      mask-repeat: no-repeat;
      mask-image: var(--mask-chat);
      mask-position: 0px -1px;
      mask-size: 13px;
    }
  }
  .timeline {
    position: relative;
    display: flex;
    > li {
      position: relative;
      display: grid;
      flex-shrink: 0;
      align-items: center;
      grid-template-rows: var(--timeline-row-start, minmax(0, 1fr)) auto var( --timeline-row-end, minmax(0, 1fr) );
      grid-template-columns: var(--timeline-col-start, minmax(0, 1fr)) auto var( --timeline-col-end, minmax(0, 1fr) );
      > hr {
        border: none;
        width: 100%;
        &:first-child {
          grid-column-start: 1;
          grid-row-start: 2;
        }
        &:last-child {
          grid-column-start: 3;
          grid-column-end: none;
          grid-row-start: 2;
          grid-row-end: auto;
        }
        @media print {
          border: 0.1px solid var(--color-base-300);
        }
      }
    }
    :where(hr) {
      height: calc(0.25rem * 1);
      background-color: var(--color-base-300);
    }
    &:has(.timeline-middle hr) {
      &:first-child {
        border-start-start-radius: 0;
        border-end-start-radius: 0;
        border-start-end-radius: var(--radius-selector);
        border-end-end-radius: var(--radius-selector);
      }
      &:last-child {
        border-start-start-radius: var(--radius-selector);
        border-end-start-radius: var(--radius-selector);
        border-start-end-radius: 0;
        border-end-end-radius: 0;
      }
    }
    &:not(:has(.timeline-middle)) {
      :first-child hr:last-child {
        border-start-start-radius: var(--radius-selector);
        border-end-start-radius: var(--radius-selector);
        border-start-end-radius: 0;
        border-end-end-radius: 0;
      }
      :last-child hr:first-child {
        border-start-start-radius: 0;
        border-end-start-radius: 0;
        border-start-end-radius: var(--radius-selector);
        border-end-end-radius: var(--radius-selector);
      }
    }
  }
  .card {
    position: relative;
    display: flex;
    flex-direction: column;
    border-radius: var(--radius-box);
    outline-width: 2px;
    transition: outline 0.2s ease-in-out;
    outline: 0 solid #0000;
    outline-offset: 2px;
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
      @media (forced-colors: active) {
        outline: 2px solid transparent;
        outline-offset: 2px;
      }
    }
    &:focus-visible {
      outline-color: currentColor;
    }
    :where(figure:first-child) {
      overflow: hidden;
      border-start-start-radius: inherit;
      border-start-end-radius: inherit;
      border-end-start-radius: unset;
      border-end-end-radius: unset;
    }
    :where(figure:last-child) {
      overflow: hidden;
      border-start-start-radius: unset;
      border-start-end-radius: unset;
      border-end-start-radius: inherit;
      border-end-end-radius: inherit;
    }
    &:where(.card-border) {
      border: var(--border) solid var(--color-base-200);
    }
    &:where(.card-dash) {
      border: var(--border) dashed var(--color-base-200);
    }
    &.image-full {
      display: grid;
      &:before {
        position: relative;
        grid-column-start: 1;
        grid-row-start: 1;
        border-radius: var(--radius-box);
        background-color: var(--color-neutral);
        opacity: 75%;
        content: "";
      }
      > * {
        grid-column-start: 1;
        grid-row-start: 1;
      }
      > .card-body {
        position: relative;
        color: var(--color-neutral-content);
      }
      :where(figure) {
        overflow: hidden;
        border-radius: inherit;
      }
      > figure img {
        height: 100%;
        object-fit: cover;
      }
    }
    figure {
      display: flex;
      align-items: center;
      justify-content: center;
    }
    &:has(> input:is(input[type="checkbox"], input[type="radio"])) {
      cursor: pointer;
      user-select: none;
    }
    &:has(> :checked) {
      outline: 2px solid currentColor;
    }
  }
  .swap {
    position: relative;
    display: inline-grid;
    cursor: pointer;
    place-content: center;
    vertical-align: middle;
    webkit-user-select: none;
    user-select: none;
    input {
      appearance: none;
      border: none;
    }
    > * {
      grid-column-start: 1;
      grid-row-start: 1;
      transition-property: transform, rotate, opacity;
      transition-duration: 0.2s;
      transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
    }
    .swap-on, .swap-indeterminate, input:indeterminate ~ .swap-on {
      opacity: 0%;
    }
    input:is(:checked, :indeterminate) {
      & ~ .swap-off {
        opacity: 0%;
      }
    }
    input:checked ~ .swap-on, input:indeterminate ~ .swap-indeterminate {
      opacity: 100%;
    }
  }
  .collapse-title {
    grid-column-start: 1;
    grid-row-start: 1;
    position: relative;
    width: 100%;
    padding: 1rem;
    padding-inline-end: 3rem;
    min-height: 3.75rem;
    transition: background-color 0.2s ease-out;
  }
  .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;
  }
  .mockup-browser {
    position: relative;
    overflow: hidden;
    overflow-x: auto;
    border-radius: var(--radius-box);
    pre[data-prefix] {
      &:before {
        content: attr(data-prefix);
        display: inline-block;
        text-align: right;
      }
    }
    .mockup-browser-toolbar {
      margin-block: calc(0.25rem * 3);
      display: inline-flex;
      width: 100%;
      align-items: center;
      padding-right: 1.4em;
      &:where(:dir(rtl), [dir="rtl"], [dir="rtl"] *) {
        flex-direction: row-reverse;
      }
      &:before {
        content: "";
        margin-right: 4.8rem;
        display: inline-block;
        aspect-ratio: 1 / 1;
        height: calc(0.25rem * 3);
        border-radius: calc(infinity * 1px);
        opacity: 30%;
        box-shadow: 1.4em 0, 2.8em 0, 4.2em 0;
      }
      .input {
        margin-inline: auto;
        display: flex;
        height: 100%;
        align-items: center;
        gap: calc(0.25rem * 2);
        overflow: hidden;
        background-color: var(--color-base-200);
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: 0.75rem;
        direction: ltr;
        &:before {
          content: "";
          width: calc(0.25rem * 4);
          height: calc(0.25rem * 4);
          opacity: 30%;
          background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='currentColor' class='size-4'%3E%3Cpath fill-rule='evenodd' d='M9.965 11.026a5 5 0 1 1 1.06-1.06l2.755 2.754a.75.75 0 1 1-1.06 1.06l-2.755-2.754ZM10.5 7a3.5 3.5 0 1 1-7 0 3.5 3.5 0 0 1 7 0Z' clip-rule='evenodd' /%3E%3C/svg%3E%0A");
        }
      }
    }
  }
  .select {
    border: var(--border) solid #0000;
    position: relative;
    display: inline-flex;
    flex-shrink: 1;
    appearance: none;
    align-items: center;
    gap: calc(0.25rem * 1.5);
    background-color: var(--color-base-100);
    padding-inline-start: calc(0.25rem * 4);
    padding-inline-end: calc(0.25rem * 7);
    vertical-align: middle;
    width: clamp(3rem, 20rem, 100%);
    height: var(--size);
    font-size: 0.875rem;
    border-start-start-radius: var(--join-ss, var(--radius-field));
    border-start-end-radius: var(--join-se, var(--radius-field));
    border-end-start-radius: var(--join-es, var(--radius-field));
    border-end-end-radius: var(--join-ee, var(--radius-field));
    background-image: linear-gradient(45deg, #0000 50%, currentColor 50%), linear-gradient(135deg, currentColor 50%, #0000 50%);
    background-position: calc(100% - 20px) calc(1px + 50%), calc(100% - 16.1px) calc(1px + 50%);
    background-size: 4px 4px, 4px 4px;
    background-repeat: no-repeat;
    text-overflow: ellipsis;
    box-shadow: 0 1px var(--input-color) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset;
    @supports (color: color-mix(in lab, red, red)) {
      box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset;
    }
    border-color: var(--input-color);
    --input-color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      --input-color: color-mix(in oklab, var(--color-base-content) 20%, #0000);
    }
    --size: calc(var(--size-field, 0.25rem) * 10);
    [dir="rtl"] & {
      background-position: calc(0% + 12px) calc(1px + 50%), calc(0% + 16px) calc(1px + 50%);
    }
    select {
      margin-inline-start: calc(0.25rem * -4);
      margin-inline-end: calc(0.25rem * -7);
      width: calc(100% + 2.75rem);
      appearance: none;
      padding-inline-start: calc(0.25rem * 4);
      padding-inline-end: calc(0.25rem * 7);
      height: calc(100% - 2px);
      background: inherit;
      border-radius: inherit;
      border-style: none;
      &:focus, &:focus-within {
        --tw-outline-style: none;
        outline-style: none;
        @media (forced-colors: active) {
          outline: 2px solid transparent;
          outline-offset: 2px;
        }
      }
      &:not(:last-child) {
        margin-inline-end: calc(0.25rem * -5.5);
        background-image: none;
      }
    }
    &:focus, &:focus-within {
      --input-color: var(--color-base-content);
      box-shadow: 0 1px var(--input-color);
      @supports (color: color-mix(in lab, red, red)) {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000);
      }
      outline: 2px solid var(--input-color);
      outline-offset: 2px;
    }
    &:has(> select[disabled]), &:is(:disabled, [disabled]) {
      cursor: not-allowed;
      border-color: var(--color-base-200);
      background-color: var(--color-base-200);
      color: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-base-content) 40%, transparent);
      }
      &::placeholder {
        color: var(--color-base-content);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
        }
      }
    }
    &:has(> select[disabled]) > select[disabled] {
      cursor: not-allowed;
    }
  }
  .menu-horizontal {
    display: inline-flex;
    flex-direction: row;
    & > li:not(.menu-title) > details > ul {
      position: absolute;
      margin-inline-start: calc(0.25rem * 0);
      margin-top: calc(0.25rem * 4);
      padding-block: calc(0.25rem * 2);
      padding-inline-end: calc(0.25rem * 2);
    }
    & > li > details > ul {
      &:before {
        content: none;
      }
    }
    :where(& > li:not(.menu-title) > details > ul) {
      border-radius: var(--radius-box);
      background-color: var(--color-base-100);
      box-shadow: 0 1px 3px 0 oklch(0% 0 0/0.1), 0 1px 2px -1px oklch(0% 0 0/0.1);
    }
  }
  .menu-vertical {
    display: inline-flex;
    flex-direction: column;
    & > li:not(.menu-title) > details > ul {
      position: relative;
      margin-inline-start: calc(0.25rem * 4);
      margin-top: calc(0.25rem * 0);
      padding-block: calc(0.25rem * 0);
      padding-inline-end: calc(0.25rem * 0);
    }
  }
  .mockup-code {
    position: relative;
    overflow: hidden;
    overflow-x: auto;
    border-radius: var(--radius-box);
    background-color: var(--color-neutral);
    padding-block: calc(0.25rem * 5);
    color: var(--color-neutral-content);
    font-size: 0.875rem;
    direction: ltr;
    &:before {
      content: "";
      margin-bottom: calc(0.25rem * 4);
      display: block;
      height: calc(0.25rem * 3);
      width: calc(0.25rem * 3);
      border-radius: calc(infinity * 1px);
      opacity: 30%;
      box-shadow: 1.4em 0, 2.8em 0, 4.2em 0;
    }
    pre {
      padding-right: calc(0.25rem * 5);
      &:before {
        content: "";
        margin-right: 2ch;
      }
      &[data-prefix] {
        &:before {
          content: attr(data-prefix);
          display: inline-block;
          width: calc(0.25rem * 8);
          text-align: right;
          opacity: 50%;
        }
      }
    }
  }
  .mockup-window {
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    overflow-x: auto;
    border-radius: var(--radius-box);
    padding-top: calc(0.25rem * 5);
    &:before {
      content: "";
      margin-bottom: calc(0.25rem * 4);
      display: block;
      aspect-ratio: 1 / 1;
      height: calc(0.25rem * 3);
      flex-shrink: 0;
      align-self: flex-start;
      border-radius: calc(infinity * 1px);
      opacity: 30%;
      box-shadow: 1.4em 0, 2.8em 0, 4.2em 0;
    }
    [dir="rtl"] &:before {
      align-self: flex-end;
    }
    pre[data-prefix] {
      &:before {
        content: attr(data-prefix);
        display: inline-block;
        text-align: right;
      }
    }
  }
  .avatar {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
    & > div {
      display: block;
      aspect-ratio: 1 / 1;
      overflow: hidden;
    }
    img {
      height: 100%;
      width: 100%;
      object-fit: cover;
    }
  }
  .checkbox {
    border: var(--border) solid var(--input-color, var(--color-base-content));
    @supports (color: color-mix(in lab, red, red)) {
      border: var(--border) solid var(--input-color, color-mix(in oklab, var(--color-base-content) 20%, #0000));
    }
    position: relative;
    flex-shrink: 0;
    cursor: pointer;
    appearance: none;
    border-radius: var(--radius-selector);
    padding: calc(0.25rem * 1);
    vertical-align: middle;
    color: var(--color-base-content);
    box-shadow: 0 1px oklch(0% 0 0 / calc(var(--depth) * 0.1)) inset, 0 0 #0000 inset, 0 0 #0000;
    transition: background-color 0.2s, box-shadow 0.2s;
    --size: calc(var(--size-selector, 0.25rem) * 6);
    width: var(--size);
    height: var(--size);
    background-size: auto, calc(var(--noise) * 100%);
    background-image: none, var(--fx-noise);
    &:before {
      --tw-content: "";
      content: var(--tw-content);
      display: block;
      width: 100%;
      height: 100%;
      rotate: 45deg;
      background-color: currentColor;
      opacity: 0%;
      transition: clip-path 0.3s, opacity 0.1s, rotate 0.3s, translate 0.3s;
      transition-delay: 0.1s;
      clip-path: polygon(20% 100%, 20% 80%, 50% 80%, 50% 80%, 70% 80%, 70% 100%);
      box-shadow: 0px 3px 0 0px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset;
      font-size: 1rem;
      line-height: 0.75;
    }
    &:focus-visible {
      outline: 2px solid var(--input-color, currentColor);
      outline-offset: 2px;
    }
    &:checked, &[aria-checked="true"] {
      background-color: var(--input-color, #0000);
      box-shadow: 0 0 #0000 inset, 0 8px 0 -4px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px oklch(0% 0 0 / calc(var(--depth) * 0.1));
      &:before {
        clip-path: polygon(20% 100%, 20% 80%, 50% 80%, 50% 0%, 70% 0%, 70% 100%);
        opacity: 100%;
      }
      @media (forced-colors: active) {
        &:before {
          rotate: 0deg;
          background-color: transparent;
          --tw-content: "✔︎";
          clip-path: none;
        }
      }
      @media print {
        &:before {
          rotate: 0deg;
          background-color: transparent;
          --tw-content: "✔︎";
          clip-path: none;
        }
      }
    }
    &:indeterminate {
      &:before {
        rotate: 0deg;
        opacity: 100%;
        translate: 0 -35%;
        clip-path: polygon(20% 100%, 20% 80%, 50% 80%, 50% 80%, 80% 80%, 80% 100%);
      }
    }
    &:disabled {
      cursor: not-allowed;
      opacity: 20%;
    }
  }
  .radio {
    position: relative;
    flex-shrink: 0;
    cursor: pointer;
    appearance: none;
    border-radius: calc(infinity * 1px);
    padding: calc(0.25rem * 1);
    vertical-align: middle;
    border: var(--border) solid var(--input-color, currentColor);
    @supports (color: color-mix(in lab, red, red)) {
      border: var(--border) solid var(--input-color, color-mix(in srgb, currentColor 20%, #0000));
    }
    box-shadow: 0 1px oklch(0% 0 0 / calc(var(--depth) * 0.1)) inset;
    --size: calc(var(--size-selector, 0.25rem) * 6);
    width: var(--size);
    height: var(--size);
    color: var(--input-color, currentColor);
    &:before {
      display: block;
      width: 100%;
      height: 100%;
      border-radius: calc(infinity * 1px);
      --tw-content: "";
      content: var(--tw-content);
      background-size: auto, calc(var(--noise) * 100%);
      background-image: none, var(--fx-noise);
    }
    &:focus-visible {
      outline: 2px solid currentColor;
    }
    &:checked, &[aria-checked="true"] {
      animation: radio 0.2s ease-out;
      border-color: currentColor;
      background-color: var(--color-base-100);
      &:before {
        background-color: currentColor;
        box-shadow: 0 -1px oklch(0% 0 0 / calc(var(--depth) * 0.1)) inset, 0 8px 0 -4px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px oklch(0% 0 0 / calc(var(--depth) * 0.1));
      }
      @media (forced-colors: active) {
        &:before {
          outline-style: var(--tw-outline-style);
          outline-width: 1px;
          outline-offset: calc(1px * -1);
        }
      }
      @media print {
        &:before {
          outline: 0.25rem solid;
          outline-offset: -1rem;
        }
      }
    }
    &:disabled {
      cursor: not-allowed;
      opacity: 20%;
    }
  }
  .rating {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
    & input {
      border: none;
      appearance: none;
    }
    :where(*) {
      animation: rating 0.25s ease-out;
      height: calc(0.25rem * 6);
      width: calc(0.25rem * 6);
      border-radius: 0;
      background-color: var(--color-base-content);
      opacity: 20%;
      &:is(input) {
        cursor: pointer;
      }
    }
    & .rating-hidden {
      width: calc(0.25rem * 2);
      background-color: transparent;
    }
    input[type="radio"]:checked {
      background-image: none;
    }
    * {
      &:checked, &[aria-checked="true"], &[aria-current="true"], &:has(~ *:checked, ~ *[aria-checked="true"], ~ *[aria-current="true"]) {
        opacity: 100%;
      }
      &:focus-visible {
        transition: scale 0.2s ease-out;
        scale: 1.1;
      }
    }
    & *:active:focus {
      animation: none;
      scale: 1.1;
    }
    &.rating-xs :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 4);
      height: calc(0.25rem * 4);
    }
    &.rating-sm :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 5);
      height: calc(0.25rem * 5);
    }
    &.rating-md :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 6);
      height: calc(0.25rem * 6);
    }
    &.rating-lg :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 7);
      height: calc(0.25rem * 7);
    }
    &.rating-xl :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 8);
      height: calc(0.25rem * 8);
    }
  }
  .rating\! {
    position: relative !important;
    display: inline-flex !important;
    vertical-align: middle !important;
    & input {
      border: none !important;
      appearance: none !important;
    }
    :where(*) {
      animation: rating 0.25s ease-out !important;
      height: calc(0.25rem * 6) !important;
      width: calc(0.25rem * 6) !important;
      border-radius: 0 !important;
      background-color: var(--color-base-content) !important;
      opacity: 20% !important;
      &:is(input) {
        cursor: pointer !important;
      }
    }
    & .rating-hidden {
      width: calc(0.25rem * 2) !important;
      background-color: transparent !important;
    }
    input[type="radio"]:checked {
      background-image: none !important;
    }
    * {
      &:checked, &[aria-checked="true"], &[aria-current="true"], &:has(~ *:checked, ~ *[aria-checked="true"], ~ *[aria-current="true"]) {
        opacity: 100% !important;
      }
      &:focus-visible {
        transition: scale 0.2s ease-out !important;
        scale: 1.1 !important;
      }
    }
    & *:active:focus {
      animation: none !important;
      scale: 1.1 !important;
    }
    &.rating-xs :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 4) !important;
      height: calc(0.25rem * 4) !important;
    }
    &.rating-sm :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 5) !important;
      height: calc(0.25rem * 5) !important;
    }
    &.rating-md :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 6) !important;
      height: calc(0.25rem * 6) !important;
    }
    &.rating-lg :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 7) !important;
      height: calc(0.25rem * 7) !important;
    }
    &.rating-xl :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 8) !important;
      height: calc(0.25rem * 8) !important;
    }
  }
  .drawer {
    position: relative;
    display: grid;
    width: 100%;
    grid-auto-columns: max-content auto;
  }
  .stats {
    position: relative;
    display: inline-grid;
    grid-auto-flow: column;
    overflow-x: auto;
    border-radius: var(--radius-box);
  }
  .progress {
    position: relative;
    height: calc(0.25rem * 2);
    width: 100%;
    appearance: none;
    overflow: hidden;
    border-radius: var(--radius-box);
    background-color: currentColor;
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, currentColor 20%, transparent);
    }
    color: var(--color-base-content);
    &:indeterminate {
      background-image: repeating-linear-gradient( 90deg, currentColor -1%, currentColor 10%, #0000 10%, #0000 90% );
      background-size: 200%;
      background-position-x: 15%;
      animation: progress 5s ease-in-out infinite;
      @supports (-moz-appearance: none) {
        &::-moz-progress-bar {
          background-color: transparent;
          background-image: repeating-linear-gradient( 90deg, currentColor -1%, currentColor 10%, #0000 10%, #0000 90% );
          background-size: 200%;
          background-position-x: 15%;
          animation: progress 5s ease-in-out infinite;
        }
      }
    }
    @supports (-moz-appearance: none) {
      &::-moz-progress-bar {
        border-radius: var(--radius-box);
        background-color: currentColor;
      }
    }
    @supports (-webkit-appearance: none) {
      &::-webkit-progress-bar {
        border-radius: var(--radius-box);
        background-color: transparent;
      }
      &::-webkit-progress-value {
        border-radius: var(--radius-box);
        background-color: currentColor;
      }
    }
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .tooltip-bottom {
    > .tooltip-content, &[data-tip]:before {
      transform: translateX(-50%) translateY(var(--tt-pos, -0.25rem));
      inset: var(--tt-off) auto auto 50%;
    }
    &:after {
      transform: translateX(-50%) translateY(var(--tt-pos, -0.25rem)) rotate(180deg);
      inset: var(--tt-tail) auto auto 50%;
    }
  }
  .tooltip-left {
    > .tooltip-content, &[data-tip]:before {
      transform: translateX(calc(var(--tt-pos, 0.25rem) - 0.25rem)) translateY(-50%);
      inset: 50% var(--tt-off) auto auto;
    }
    &:after {
      transform: translateX(var(--tt-pos, 0.25rem)) translateY(-50%) rotate(-90deg);
      inset: 50% calc(var(--tt-tail) + 1px) auto auto;
    }
  }
  .tooltip-right {
    > .tooltip-content, &[data-tip]:before {
      transform: translateX(calc(var(--tt-pos, -0.25rem) + 0.25rem)) translateY(-50%);
      inset: 50% auto auto var(--tt-off);
    }
    &:after {
      transform: translateX(var(--tt-pos, -0.25rem)) translateY(-50%) rotate(90deg);
      inset: 50% auto auto calc(var(--tt-tail) + 1px);
    }
  }
  .tooltip-top {
    > .tooltip-content, &[data-tip]:before {
      transform: translateX(-50%) translateY(var(--tt-pos, 0.25rem));
      inset: auto auto var(--tt-off) 50%;
    }
    &:after {
      transform: translateX(-50%) translateY(var(--tt-pos, 0.25rem));
      inset: auto auto var(--tt-tail) 50%;
    }
  }
  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }
  .inset-y-0 {
    inset-block: calc(var(--spacing) * 0);
  }
  .dropdown-right {
    --anchor-h: right;
    --anchor-v: span-bottom;
    .dropdown-content {
      inset-inline-start: 100%;
      top: calc(0.25rem * 0);
      bottom: auto;
      transform-origin: left;
    }
  }
  .chat-end {
    place-items: end;
    grid-template-columns: 1fr auto;
    .chat-header {
      grid-column-start: 1;
    }
    .chat-footer {
      grid-column-start: 1;
    }
    .chat-image {
      grid-column-start: 2;
    }
    .chat-bubble {
      grid-column-start: 1;
      border-end-end-radius: 0;
      &:before {
        transform: rotateY(180deg);
        inset-inline-start: 100%;
      }
      [dir="rtl"] &:before {
        transform: rotateY(0deg);
      }
    }
  }
  .chat-start {
    place-items: start;
    grid-template-columns: auto 1fr;
    .chat-header {
      grid-column-start: 2;
    }
    .chat-footer {
      grid-column-start: 2;
    }
    .chat-image {
      grid-column-start: 1;
    }
    .chat-bubble {
      grid-column-start: 2;
      border-end-start-radius: 0;
      &:before {
        transform: rotateY(0deg);
        inset-inline-start: -0.75rem;
      }
      [dir="rtl"] &:before {
        transform: rotateY(180deg);
      }
    }
  }
  .dropdown-left {
    --anchor-h: left;
    --anchor-v: span-bottom;
    .dropdown-content {
      inset-inline-end: 100%;
      top: calc(0.25rem * 0);
      bottom: auto;
      transform-origin: right;
    }
  }
  .dropdown-center {
    --anchor-h: center;
    :where(.dropdown-content) {
      inset-inline-end: calc(1/2 * 100%);
      translate: 50% 0;
    }
    &.dropdown-left {
      --anchor-h: left;
      --anchor-v: center;
      .dropdown-content {
        top: auto;
        bottom: calc(1/2 * 100%);
        translate: 0 50%;
      }
    }
    &.dropdown-right {
      --anchor-h: right;
      --anchor-v: center;
      .dropdown-content {
        top: auto;
        bottom: calc(1/2 * 100%);
        translate: 0 50%;
      }
    }
  }
  .dropdown-end {
    --anchor-h: span-left;
    :where(.dropdown-content) {
      inset-inline-end: calc(0.25rem * 0);
      translate: 0 0;
    }
    &.dropdown-left {
      --anchor-h: left;
      --anchor-v: span-top;
      .dropdown-content {
        top: auto;
        bottom: calc(0.25rem * 0);
      }
    }
    &.dropdown-right {
      --anchor-h: right;
      --anchor-v: span-top;
      .dropdown-content {
        top: auto;
        bottom: calc(0.25rem * 0);
      }
    }
  }
  .dropdown-start {
    --anchor-h: span-right;
    :where(.dropdown-content) {
      inset-inline-end: auto;
    }
    &.dropdown-left {
      --anchor-h: left;
      --anchor-v: span-bottom;
      .dropdown-content {
        top: calc(0.25rem * 0);
        bottom: auto;
      }
    }
    &.dropdown-right {
      --anchor-h: right;
      --anchor-v: span-bottom;
      .dropdown-content {
        top: calc(0.25rem * 0);
        bottom: auto;
      }
    }
  }
  .dropdown-bottom {
    --anchor-v: bottom;
    .dropdown-content {
      top: 100%;
      bottom: auto;
      transform-origin: top;
    }
  }
  .dropdown-top {
    --anchor-v: top;
    .dropdown-content {
      top: auto;
      bottom: 100%;
      transform-origin: bottom;
    }
  }
  .-top-1 {
    top: calc(var(--spacing) * -1);
  }
  .-top-2 {
    top: calc(var(--spacing) * -2);
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .top-0\.5 {
    top: calc(var(--spacing) * 0.5);
  }
  .top-1 {
    top: calc(var(--spacing) * 1);
  }
  .top-1\/2 {
    top: calc(1/2 * 100%);
  }
  .top-3 {
    top: calc(var(--spacing) * 3);
  }
  .top-4 {
    top: calc(var(--spacing) * 4);
  }
  .top-full {
    top: 100%;
  }
  .-right-1 {
    right: calc(var(--spacing) * -1);
  }
  .-right-2 {
    right: calc(var(--spacing) * -2);
  }
  .right-0 {
    right: calc(var(--spacing) * 0);
  }
  .right-1 {
    right: calc(var(--spacing) * 1);
  }
  .right-3 {
    right: calc(var(--spacing) * 3);
  }
  .right-4 {
    right: calc(var(--spacing) * 4);
  }
  .dock-sm {
    height: calc(0.25rem * 14);
    height: 3.5rem;
    height: calc(3.5rem + env(safe-area-inset-bottom));
    .dock-active {
      &:after {
        bottom: -0.1rem;
      }
    }
    .dock-label {
      font-size: 0.625rem;
    }
  }
  .dock-lg {
    height: 4.5rem;
    height: calc(4.5rem + env(safe-area-inset-bottom));
    .dock-active {
      &:after {
        bottom: 0.4rem;
      }
    }
    .dock-label {
      font-size: 0.6875rem;
    }
  }
  .dock-xl {
    height: 5rem;
    height: calc(5rem + env(safe-area-inset-bottom));
    .dock-active {
      &:after {
        bottom: 0.4rem;
      }
    }
    .dock-label {
      font-size: 0.75rem;
    }
  }
  .dock-xs {
    height: 3rem;
    height: calc(3rem + env(safe-area-inset-bottom));
    .dock-active {
      &:after {
        bottom: -0.1rem;
      }
    }
    .dock-label {
      font-size: 0.625rem;
    }
  }
  .-bottom-1 {
    bottom: calc(var(--spacing) * -1);
  }
  .-bottom-6 {
    bottom: calc(var(--spacing) * -6);
  }
  .bottom-0 {
    bottom: calc(var(--spacing) * 0);
  }
  .left-0 {
    left: calc(var(--spacing) * 0);
  }
  .left-0\.5 {
    left: calc(var(--spacing) * 0.5);
  }
  .left-1\/2 {
    left: calc(1/2 * 100%);
  }
  .left-3 {
    left: calc(var(--spacing) * 3);
  }
  .left-3\.5 {
    left: calc(var(--spacing) * 3.5);
  }
  .file-input {
    cursor: pointer;
    cursor: pointer;
    border: var(--border) solid #0000;
    display: inline-flex;
    appearance: none;
    align-items: center;
    background-color: var(--color-base-100);
    vertical-align: middle;
    webkit-user-select: none;
    user-select: none;
    width: clamp(3rem, 20rem, 100%);
    height: var(--size);
    padding-inline-end: 0.75rem;
    font-size: 0.875rem;
    line-height: 2;
    border-start-start-radius: var(--join-ss, var(--radius-field));
    border-start-end-radius: var(--join-se, var(--radius-field));
    border-end-start-radius: var(--join-es, var(--radius-field));
    border-end-end-radius: var(--join-ee, var(--radius-field));
    border-color: var(--input-color);
    box-shadow: 0 1px var(--input-color) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset;
    @supports (color: color-mix(in lab, red, red)) {
      box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset;
    }
    --size: calc(var(--size-field, 0.25rem) * 10);
    --input-color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      --input-color: color-mix(in oklab, var(--color-base-content) 20%, #0000);
    }
    &::file-selector-button {
      margin-inline-end: calc(0.25rem * 4);
      cursor: pointer;
      padding-inline: calc(0.25rem * 4);
      webkit-user-select: none;
      user-select: none;
      height: calc(100% + var(--border) * 2);
      margin-block: calc(var(--border) * -1);
      margin-inline-start: calc(var(--border) * -1);
      font-size: 0.875rem;
      color: var(--btn-fg);
      border-width: var(--border);
      border-style: solid;
      border-color: var(--btn-border);
      border-start-start-radius: calc(var(--join-ss, var(--radius-field) - var(--border)));
      border-end-start-radius: calc(var(--join-es, var(--radius-field) - var(--border)));
      font-weight: 600;
      background-color: var(--btn-bg);
      background-size: calc(var(--noise) * 100%);
      background-image: var(--btn-noise);
      text-shadow: 0 0.5px oklch(1 0 0 / calc(var(--depth) * 0.15));
      box-shadow: 0 0.5px 0 0.5px white inset, var(--btn-shadow);
      @supports (color: color-mix(in lab, red, red)) {
        box-shadow: 0 0.5px 0 0.5px color-mix( in oklab, color-mix(in oklab, white 30%, var(--btn-bg)) calc(var(--depth) * 20%), #0000 ) inset, var(--btn-shadow);
      }
      --size: calc(var(--size-field, 0.25rem) * 10);
      --btn-bg: var(--btn-color, var(--color-base-200));
      --btn-fg: var(--color-base-content);
      --btn-border: var(--btn-bg);
      @supports (color: color-mix(in lab, red, red)) {
        --btn-border: color-mix(in oklab, var(--btn-bg), #000 5%);
      }
      --btn-shadow: 0 3px 2px -2px var(--btn-bg),
      0 4px 3px -2px var(--btn-bg);
      @supports (color: color-mix(in lab, red, red)) {
        --btn-shadow: 0 3px 2px -2px color-mix(in oklab, var(--btn-bg) 30%, #0000),
      0 4px 3px -2px color-mix(in oklab, var(--btn-bg) 30%, #0000);
      }
      --btn-noise: var(--fx-noise);
    }
    &:focus {
      --input-color: var(--color-base-content);
      box-shadow: 0 1px var(--input-color);
      @supports (color: color-mix(in lab, red, red)) {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) 10%, #0000);
      }
      outline: 2px solid var(--input-color);
      outline-offset: 2px;
      isolation: isolate;
    }
    &:has(> input[disabled]), &:is(:disabled, [disabled]) {
      cursor: not-allowed;
      border-color: var(--color-base-200);
      background-color: var(--color-base-200);
      &::placeholder {
        color: var(--color-base-content);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
        }
      }
      box-shadow: none;
      color: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklch, var(--color-base-content) 20%, #0000);
      }
      &::file-selector-button {
        cursor: not-allowed;
        border-color: var(--color-base-200);
        background-color: var(--color-base-200);
        --btn-border: #0000;
        --btn-noise: none;
        --btn-fg: var(--color-base-content);
        @supports (color: color-mix(in lab, red, red)) {
          --btn-fg: color-mix(in oklch, var(--color-base-content) 20%, #0000);
        }
      }
    }
  }
  .hero-content {
    isolation: isolate;
    display: flex;
    max-width: 80rem;
    align-items: center;
    justify-content: center;
    gap: calc(0.25rem * 4);
    padding: calc(0.25rem * 4);
  }
  .textarea {
    border: var(--border) solid #0000;
    min-height: calc(0.25rem * 20);
    flex-shrink: 1;
    appearance: none;
    border-radius: var(--radius-field);
    background-color: var(--color-base-100);
    padding-block: calc(0.25rem * 2);
    vertical-align: middle;
    width: clamp(3rem, 20rem, 100%);
    padding-inline-start: 0.75rem;
    padding-inline-end: 0.75rem;
    font-size: 0.875rem;
    border-color: var(--input-color);
    box-shadow: 0 1px var(--input-color) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset;
    @supports (color: color-mix(in lab, red, red)) {
      box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000) inset, 0 -1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset;
    }
    --input-color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      --input-color: color-mix(in oklab, var(--color-base-content) 20%, #0000);
    }
    textarea {
      appearance: none;
      background-color: transparent;
      border: none;
      &:focus, &:focus-within {
        --tw-outline-style: none;
        outline-style: none;
        @media (forced-colors: active) {
          outline: 2px solid transparent;
          outline-offset: 2px;
        }
      }
    }
    &:focus, &:focus-within {
      --input-color: var(--color-base-content);
      box-shadow: 0 1px var(--input-color);
      @supports (color: color-mix(in lab, red, red)) {
        box-shadow: 0 1px color-mix(in oklab, var(--input-color) calc(var(--depth) * 10%), #0000);
      }
      outline: 2px solid var(--input-color);
      outline-offset: 2px;
      isolation: isolate;
    }
    &:has(> textarea[disabled]), &:is(:disabled, [disabled]) {
      cursor: not-allowed;
      border-color: var(--color-base-200);
      background-color: var(--color-base-200);
      color: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-base-content) 40%, transparent);
      }
      &::placeholder {
        color: var(--color-base-content);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
        }
      }
      box-shadow: none;
    }
    &:has(> textarea[disabled]) > textarea[disabled] {
      cursor: not-allowed;
    }
  }
  .btn-active {
    --btn-bg: var(--btn-color, var(--color-base-200));
    @supports (color: color-mix(in lab, red, red)) {
      --btn-bg: color-mix(in oklab, var(--btn-color, var(--color-base-200)), #000 7%);
    }
    --btn-shadow: 0 0 0 0 oklch(0% 0 0/0), 0 0 0 0 oklch(0% 0 0/0);
    isolation: isolate;
  }
  .isolate {
    isolation: isolate;
  }
  .mockup-phone-camera {
    grid-column: 1/1;
    grid-row: 1/1;
    background: #000;
    height: 32px;
    width: 126px;
    border-radius: 17px;
    z-index: 1;
    margin-top: 6px;
  }
  .stack {
    display: inline-grid;
    grid-template-columns: 3px 4px 1fr 4px 3px;
    grid-template-rows: 3px 4px 1fr 4px 3px;
    & > * {
      height: 100%;
      width: 100%;
      &:nth-child(n + 2) {
        width: 100%;
        opacity: 70%;
      }
      &:nth-child(2) {
        z-index: 2;
        opacity: 90%;
      }
      &:nth-child(1) {
        z-index: 3;
        width: 100%;
      }
    }
    &, &.stack-bottom {
      > * {
        grid-column: 3 / 4;
        grid-row: 3 / 6;
        &:nth-child(2) {
          grid-column: 2 / 5;
          grid-row: 2 / 5;
        }
        &:nth-child(1) {
          grid-column: 1 / 6;
          grid-row: 1 / 4;
        }
      }
    }
    &.stack-top {
      > * {
        grid-column: 3 / 4;
        grid-row: 1 / 4;
        &:nth-child(2) {
          grid-column: 2 / 5;
          grid-row: 2 / 5;
        }
        &:nth-child(1) {
          grid-column: 1 / 6;
          grid-row: 3 / 6;
        }
      }
    }
    &.stack-start {
      > * {
        grid-column: 1 / 4;
        grid-row: 3 / 4;
        &:nth-child(2) {
          grid-column: 2 / 5;
          grid-row: 2 / 5;
        }
        &:nth-child(1) {
          grid-column: 3 / 6;
          grid-row: 1 / 6;
        }
      }
    }
    &.stack-end {
      > * {
        grid-column: 3 / 6;
        grid-row: 3 / 4;
        &:nth-child(2) {
          grid-column: 2 / 5;
          grid-row: 2 / 5;
        }
        &:nth-child(1) {
          grid-column: 1 / 4;
          grid-row: 1 / 6;
        }
      }
    }
  }
  .modal-backdrop {
    grid-column-start: 1;
    grid-row-start: 1;
    display: grid;
    align-self: stretch;
    justify-self: stretch;
    color: transparent;
    z-index: -1;
    button {
      cursor: pointer;
    }
  }
  .-z-10 {
    z-index: calc(10 * -1);
  }
  .z-0 {
    z-index: 0;
  }
  .z-10 {
    z-index: 10;
  }
  .z-20 {
    z-index: 20;
  }
  .z-30 {
    z-index: 30;
  }
  .z-40 {
    z-index: 40;
  }
  .z-50 {
    z-index: 50;
  }
  .tab-content {
    order: var(--tabcontent-order);
    display: none;
    border-color: transparent;
    --tabcontent-radius-ss: 0;
    --tabcontent-radius-se: 0;
    --tabcontent-radius-es: 0;
    --tabcontent-radius-ee: 0;
    --tabcontent-order: 1;
    width: 100%;
    margin: var(--tabcontent-margin);
    border-width: var(--border);
    border-start-start-radius: var(--tabcontent-radius-ss);
    border-start-end-radius: var(--tabcontent-radius-se);
    border-end-start-radius: var(--tabcontent-radius-es);
    border-end-end-radius: var(--tabcontent-radius-ee);
  }
  .mockup-phone-display {
    grid-column: 1/1;
    grid-row: 1/1;
    overflow: hidden;
    border-radius: 49px;
    width: 390px;
    height: 845px;
  }
  .col-span-2 {
    grid-column: span 2 / span 2;
  }
  .timeline-end {
    grid-column-start: 1;
    grid-column-end: 4;
    grid-row-start: 3;
    grid-row-end: 4;
    margin: calc(0.25rem * 1);
    align-self: flex-start;
    justify-self: center;
  }
  .timeline-start {
    grid-column-start: 1;
    grid-column-end: 4;
    grid-row-start: 1;
    grid-row-end: 2;
    margin: calc(0.25rem * 1);
    align-self: flex-end;
    justify-self: center;
  }
  .timeline-horizontal {
    flex-direction: row;
    > li {
      align-items: center;
      > hr {
        height: calc(0.25rem * 1);
        width: 100%;
        &:first-child {
          grid-column-start: 1;
          grid-row-start: 2;
        }
        &:last-child {
          grid-column-start: 3;
          grid-column-end: none;
          grid-row-start: 2;
          grid-row-end: auto;
        }
      }
    }
    .timeline-start {
      grid-column-start: 1;
      grid-column-end: 4;
      grid-row-start: 1;
      grid-row-end: 2;
      align-self: flex-end;
      justify-self: center;
    }
    .timeline-end {
      grid-column-start: 1;
      grid-column-end: 4;
      grid-row-start: 3;
      grid-row-end: 4;
      align-self: flex-start;
      justify-self: center;
    }
    &:has(.timeline-middle) {
      > li {
        > hr {
          &:first-child {
            border-start-start-radius: 0;
            border-end-start-radius: 0;
            border-start-end-radius: var(--radius-selector);
            border-end-end-radius: var(--radius-selector);
          }
          &:last-child {
            border-start-start-radius: var(--radius-selector);
            border-end-start-radius: var(--radius-selector);
            border-start-end-radius: 0;
            border-end-end-radius: 0;
          }
        }
      }
    }
    &:not(:has(.timeline-middle)) {
      :first-child {
        > hr:last-child {
          border-start-start-radius: var(--radius-selector);
          border-end-start-radius: var(--radius-selector);
          border-start-end-radius: 0;
          border-end-end-radius: 0;
        }
      }
      :last-child {
        > hr:first-child {
          border-start-start-radius: 0;
          border-end-start-radius: 0;
          border-start-end-radius: var(--radius-selector);
          border-end-end-radius: var(--radius-selector);
        }
      }
    }
  }
  .timeline-vertical {
    flex-direction: column;
    > li {
      justify-items: center;
      --timeline-row-start: minmax(0, 1fr);
      --timeline-row-end: minmax(0, 1fr);
      > hr {
        height: 100%;
        width: calc(0.25rem * 1);
        &:first-child {
          grid-column-start: 2;
          grid-row-start: 1;
        }
        &:last-child {
          grid-column-start: 2;
          grid-column-end: auto;
          grid-row-start: 3;
          grid-row-end: none;
        }
      }
    }
    .timeline-start {
      grid-column-start: 1;
      grid-column-end: 2;
      grid-row-start: 1;
      grid-row-end: 4;
      align-self: center;
      justify-self: flex-end;
    }
    .timeline-end {
      grid-column-start: 3;
      grid-column-end: 4;
      grid-row-start: 1;
      grid-row-end: 4;
      align-self: center;
      justify-self: flex-start;
    }
    &:has(.timeline-middle) {
      > li {
        > hr {
          &:first-child {
            border-top-left-radius: 0;
            border-top-right-radius: 0;
            border-bottom-right-radius: var(--radius-selector);
            border-bottom-left-radius: var(--radius-selector);
          }
          &:last-child {
            border-top-left-radius: var(--radius-selector);
            border-top-right-radius: var(--radius-selector);
            border-bottom-right-radius: 0;
            border-bottom-left-radius: 0;
          }
        }
      }
    }
    &:not(:has(.timeline-middle)) {
      :first-child {
        > hr:last-child {
          border-top-left-radius: var(--radius-selector);
          border-top-right-radius: var(--radius-selector);
          border-bottom-right-radius: 0;
          border-bottom-left-radius: 0;
        }
      }
      :last-child {
        > hr:first-child {
          border-top-left-radius: 0;
          border-top-right-radius: 0;
          border-bottom-right-radius: var(--radius-selector);
          border-bottom-left-radius: var(--radius-selector);
        }
      }
    }
    &.timeline-snap-icon {
      > li {
        --timeline-col-start: minmax(0, 1fr);
        --timeline-row-start: 0.5rem;
      }
    }
  }
  .timeline-compact {
    --timeline-row-start: 0;
    .timeline-start {
      grid-column-start: 1;
      grid-column-end: 4;
      grid-row-start: 3;
      grid-row-end: 4;
      align-self: flex-start;
      justify-self: center;
    }
    li:has(.timeline-start) {
      .timeline-end {
        grid-column-start: none;
        grid-row-start: auto;
      }
    }
    &.timeline-vertical {
      > li {
        --timeline-col-start: 0;
      }
      .timeline-start {
        grid-column-start: 3;
        grid-column-end: 4;
        grid-row-start: 1;
        grid-row-end: 4;
        align-self: center;
        justify-self: flex-start;
      }
      li:has(.timeline-start) {
        .timeline-end {
          grid-column-start: auto;
          grid-row-start: none;
        }
      }
    }
  }
  .stat-figure {
    grid-column-start: 2;
    grid-row: span 3 / span 3;
    grid-row-start: 1;
    place-self: center;
    justify-self: flex-end;
  }
  .hero {
    display: grid;
    width: 100%;
    place-items: center;
    background-size: cover;
    background-position: center;
    & > * {
      grid-column-start: 1;
      grid-row-start: 1;
    }
  }
  .hero-overlay {
    grid-column-start: 1;
    grid-row-start: 1;
    height: 100%;
    width: 100%;
    background-color: var(--color-neutral);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-neutral) 50%, transparent);
    }
  }
  .modal-box {
    grid-column-start: 1;
    grid-row-start: 1;
    max-height: 100vh;
    width: calc(11/12 * 100%);
    max-width: 32rem;
    background-color: var(--color-base-100);
    padding: calc(0.25rem * 6);
    transition: translate 0.3s ease-out, scale 0.3s ease-out, opacity 0.2s ease-out 0.05s, box-shadow 0.3s ease-out;
    border-top-left-radius: var(--modal-tl, var(--radius-box));
    border-top-right-radius: var(--modal-tr, var(--radius-box));
    border-bottom-left-radius: var(--modal-bl, var(--radius-box));
    border-bottom-right-radius: var(--modal-br, var(--radius-box));
    scale: 95%;
    opacity: 0;
    box-shadow: oklch(0% 0 0/ 0.25) 0px 25px 50px -12px;
    overflow-y: auto;
    overscroll-behavior: contain;
  }
  .drawer-content {
    grid-column-start: 2;
    grid-row-start: 1;
    min-width: calc(0.25rem * 0);
  }
  .timeline-middle {
    grid-column-start: 2;
    grid-row-start: 2;
  }
  .drawer-end {
    grid-auto-columns: auto max-content;
    > .drawer-toggle {
      & ~ .drawer-content {
        grid-column-start: 1;
      }
      & ~ .drawer-side {
        grid-column-start: 2;
        justify-items: end;
      }
      & ~ .drawer-side > *:not(.drawer-overlay) {
        translate: 100%;
        [dir="rtl"] & {
          translate: -100%;
        }
      }
      &:checked ~ .drawer-side > *:not(.drawer-overlay) {
        translate: 0%;
      }
    }
  }
  .stat-value {
    grid-column-start: 1;
    white-space: nowrap;
    font-size: 2rem;
    font-weight: 800;
  }
  .stat-desc {
    grid-column-start: 1;
    white-space: nowrap;
    color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-base-content) 60%, transparent);
    }
    font-size: 0.75rem;
  }
  .stat-title {
    grid-column-start: 1;
    white-space: nowrap;
    color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-base-content) 60%, transparent);
    }
    font-size: 0.75rem;
  }
  .stat-actions {
    grid-column-start: 1;
    white-space: nowrap;
  }
  .chat-image {
    grid-row: span 2 / span 2;
    align-self: flex-end;
  }
  .chat-footer {
    grid-row-start: 3;
    display: flex;
    gap: calc(0.25rem * 1);
    font-size: 0.6875rem;
  }
  .chat-header {
    grid-row-start: 1;
    display: flex;
    gap: calc(0.25rem * 1);
    font-size: 0.6875rem;
  }
  .list-col-wrap {
    grid-row-start: 2;
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .divider {
    display: flex;
    height: calc(0.25rem * 4);
    flex-direction: row;
    align-items: center;
    align-self: stretch;
    white-space: nowrap;
    margin: var(--divider-m, 1rem 0);
    &:before, &:after {
      content: "";
      height: calc(0.25rem * 0.5);
      width: 100%;
      flex-grow: 1;
      background-color: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-base-content) 10%, transparent);
      }
    }
    @media print {
      &:before, &:after {
        border: 0.5px solid;
      }
    }
    &:not(:empty) {
      gap: calc(0.25rem * 4);
    }
  }
  .m-0 {
    margin: calc(var(--spacing) * 0);
  }
  .m-7 {
    margin: calc(var(--spacing) * 7);
  }
  .filter {
    display: flex;
    flex-wrap: wrap;
    input[type="radio"] {
      width: auto;
    }
    input {
      overflow: hidden;
      opacity: 100%;
      scale: 1;
      transition: margin 0.1s, opacity 0.3s, padding 0.3s, border-width 0.1s;
      &:not(:last-child) {
        margin-inline-end: calc(0.25rem * 1);
      }
      &.filter-reset {
        aspect-ratio: 1 / 1;
        &::after {
          content: "×";
        }
      }
    }
    &:not(:has(input:checked:not(.filter-reset))) {
      .filter-reset, input[type="reset"] {
        scale: 0;
        border-width: 0;
        margin-inline: calc(0.25rem * 0);
        width: calc(0.25rem * 0);
        padding-inline: calc(0.25rem * 0);
        opacity: 0%;
      }
    }
    &:has(input:checked:not(.filter-reset)) {
      input:not(:checked, .filter-reset, input[type="reset"]) {
        scale: 0;
        border-width: 0;
        margin-inline: calc(0.25rem * 0);
        width: calc(0.25rem * 0);
        padding-inline: calc(0.25rem * 0);
        opacity: 0%;
      }
    }
  }
  .-mx-3 {
    margin-inline: calc(var(--spacing) * -3);
  }
  .mx-1 {
    margin-inline: calc(var(--spacing) * 1);
  }
  .mx-4 {
    margin-inline: calc(var(--spacing) * 4);
  }
  .mx-auto {
    margin-inline: auto;
  }
  .file-input-ghost {
    background-color: transparent;
    transition: background-color 0.2s;
    box-shadow: none;
    border-color: #0000;
    &::file-selector-button {
      margin-inline-start: calc(0.25rem * 0);
      margin-inline-end: calc(0.25rem * 4);
      height: 100%;
      cursor: pointer;
      padding-inline: calc(0.25rem * 4);
      webkit-user-select: none;
      user-select: none;
      margin-block: 0;
      border-start-end-radius: calc(var(--join-ss, var(--radius-field) - var(--border)));
      border-end-end-radius: calc(var(--join-es, var(--radius-field) - var(--border)));
    }
    &:focus, &:focus-within {
      background-color: var(--color-base-100);
      color: var(--color-base-content);
      border-color: #0000;
      box-shadow: none;
    }
  }
  .input-lg {
    --size: calc(var(--size-field, 0.25rem) * 12);
    font-size: 1.125rem;
    &[type="number"] {
      &::-webkit-inner-spin-button {
        margin-block: calc(0.25rem * -3);
        margin-inline-end: calc(0.25rem * -3);
      }
    }
  }
  .input-md {
    --size: calc(var(--size-field, 0.25rem) * 10);
    font-size: 0.875rem;
    &[type="number"] {
      &::-webkit-inner-spin-button {
        margin-block: calc(0.25rem * -3);
        margin-inline-end: calc(0.25rem * -3);
      }
    }
  }
  .input-sm {
    --size: calc(var(--size-field, 0.25rem) * 8);
    font-size: 0.75rem;
    &[type="number"] {
      &::-webkit-inner-spin-button {
        margin-block: calc(0.25rem * -2);
        margin-inline-end: calc(0.25rem * -3);
      }
    }
  }
  .input-xl {
    --size: calc(var(--size-field, 0.25rem) * 14);
    font-size: 1.375rem;
    &[type="number"] {
      &::-webkit-inner-spin-button {
        margin-block: calc(0.25rem * -4);
        margin-inline-end: calc(0.25rem * -3);
      }
    }
  }
  .input-xs {
    --size: calc(var(--size-field, 0.25rem) * 6);
    font-size: 0.6875rem;
    &[type="number"] {
      &::-webkit-inner-spin-button {
        margin-block: calc(0.25rem * -1);
        margin-inline-end: calc(0.25rem * -3);
      }
    }
  }
  .my-1 {
    margin-block: calc(var(--spacing) * 1);
  }
  .my-2 {
    margin-block: calc(var(--spacing) * 2);
  }
  .my-3 {
    margin-block: calc(var(--spacing) * 3);
  }
  .my-4 {
    margin-block: calc(var(--spacing) * 4);
  }
  .my-5 {
    margin-block: calc(var(--spacing) * 5);
  }
  .my-10 {
    margin-block: calc(var(--spacing) * 10);
  }
  .label {
    display: inline-flex;
    align-items: center;
    gap: calc(0.25rem * 1.5);
    white-space: nowrap;
    color: currentColor;
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, currentColor 60%, transparent);
    }
    &:has(input) {
      cursor: pointer;
    }
    &:is(.input > *, .select > *) {
      display: flex;
      height: calc(100% - 0.5rem);
      align-items: center;
      padding-inline: calc(0.25rem * 3);
      white-space: nowrap;
      font-size: inherit;
      &:first-child {
        margin-inline-start: calc(0.25rem * -3);
        margin-inline-end: calc(0.25rem * 3);
        border-inline-end: var(--border) solid currentColor;
        @supports (color: color-mix(in lab, red, red)) {
          border-inline-end: var(--border) solid color-mix(in oklab, currentColor 10%, #0000);
        }
      }
      &:last-child {
        margin-inline-start: calc(0.25rem * 3);
        margin-inline-end: calc(0.25rem * -3);
        border-inline-start: var(--border) solid currentColor;
        @supports (color: color-mix(in lab, red, red)) {
          border-inline-start: var(--border) solid color-mix(in oklab, currentColor 10%, #0000);
        }
      }
    }
  }
  .steps-vertical {
    grid-auto-rows: 1fr;
    grid-auto-flow: row;
    .step {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      grid-template-columns: 40px 1fr;
      grid-template-rows: repeat(1, minmax(0, 1fr));
      grid-template-rows: auto;
      gap: 0.5rem;
      min-height: 4rem;
      justify-items: start;
      &:before {
        height: 100%;
        width: calc(0.25rem * 2);
        translate: -50% -50%;
        margin-inline-start: 50%;
      }
      [dir="rtl"] &:before {
        translate: 50% -50%;
      }
    }
  }
  .steps-horizontal {
    grid-auto-columns: 1fr;
    display: inline-grid;
    grid-auto-flow: column;
    overflow: hidden;
    overflow-x: auto;
    .step {
      display: grid;
      grid-template-columns: repeat(1, minmax(0, 1fr));
      grid-template-columns: auto;
      grid-template-rows: repeat(2, minmax(0, 1fr));
      grid-template-rows: 40px 1fr;
      place-items: center;
      text-align: center;
      min-width: 4rem;
      &:before {
        height: calc(0.25rem * 2);
        width: 100%;
        translate: 0;
        content: "";
        margin-inline-start: -100%;
      }
      [dir="rtl"] &:before {
        translate: 0;
      }
    }
  }
  .join-horizontal {
    flex-direction: row;
    > .join-item:first-child {
      --join-ss: var(--radius-field);
      --join-se: 0;
      --join-es: var(--radius-field);
      --join-ee: 0;
    }
    :first-child:not(:last-child) {
      .join-item {
        --join-ss: var(--radius-field);
        --join-se: 0;
        --join-es: var(--radius-field);
        --join-ee: 0;
      }
    }
    > .join-item:last-child {
      --join-ss: 0;
      --join-se: var(--radius-field);
      --join-es: 0;
      --join-ee: var(--radius-field);
    }
    :last-child:not(:first-child) {
      .join-item {
        --join-ss: 0;
        --join-se: var(--radius-field);
        --join-es: 0;
        --join-ee: var(--radius-field);
      }
    }
    > .join-item:only-child {
      --join-ss: var(--radius-field);
      --join-se: var(--radius-field);
      --join-es: var(--radius-field);
      --join-ee: var(--radius-field);
    }
    :only-child {
      .join-item {
        --join-ss: var(--radius-field);
        --join-se: var(--radius-field);
        --join-es: var(--radius-field);
        --join-ee: var(--radius-field);
      }
    }
    .join-item {
      &:where(*:not(:first-child)) {
        margin-inline-start: calc(var(--border, 1px) * -1);
        margin-block-start: 0;
      }
    }
  }
  .join-vertical {
    flex-direction: column;
    > .join-item:first-child {
      --join-ss: var(--radius-field);
      --join-se: var(--radius-field);
      --join-es: 0;
      --join-ee: 0;
    }
    :first-child:not(:last-child) {
      .join-item {
        --join-ss: var(--radius-field);
        --join-se: var(--radius-field);
        --join-es: 0;
        --join-ee: 0;
      }
    }
    > .join-item:last-child {
      --join-ss: 0;
      --join-se: 0;
      --join-es: var(--radius-field);
      --join-ee: var(--radius-field);
    }
    :last-child:not(:first-child) {
      .join-item {
        --join-ss: 0;
        --join-se: 0;
        --join-es: var(--radius-field);
        --join-ee: var(--radius-field);
      }
    }
    > .join-item:only-child {
      --join-ss: var(--radius-field);
      --join-se: var(--radius-field);
      --join-es: var(--radius-field);
      --join-ee: var(--radius-field);
    }
    :only-child {
      .join-item {
        --join-ss: var(--radius-field);
        --join-se: var(--radius-field);
        --join-es: var(--radius-field);
        --join-ee: var(--radius-field);
      }
    }
    .join-item {
      &:where(*:not(:first-child)) {
        margin-inline-start: 0;
        margin-block-start: calc(var(--border, 1px) * -1);
      }
    }
  }
  .join-item {
    &:where(*:not(:first-child)) {
      margin-inline-start: calc(var(--border, 1px) * -1);
      margin-block-start: 0;
    }
  }
  .modal-action {
    margin-top: calc(0.25rem * 6);
    display: flex;
    justify-content: flex-end;
    gap: calc(0.25rem * 2);
  }
  .validator-hint {
    margin-top: calc(0.25rem * 2);
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }
  .mt-0\.5 {
    margin-top: calc(var(--spacing) * 0.5);
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .mt-1\.5 {
    margin-top: calc(var(--spacing) * 1.5);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mt-5 {
    margin-top: calc(var(--spacing) * 5);
  }
  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }
  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }
  .mt-10 {
    margin-top: calc(var(--spacing) * 10);
  }
  .mt-12 {
    margin-top: calc(var(--spacing) * 12);
  }
  .mt-16 {
    margin-top: calc(var(--spacing) * 16);
  }
  .breadcrumbs {
    max-width: 100%;
    overflow-x: auto;
    padding-block: calc(0.25rem * 2);
    > menu, > ul, > ol {
      display: flex;
      min-height: min-content;
      align-items: center;
      white-space: nowrap;
      > li {
        display: flex;
        align-items: center;
        > * {
          display: flex;
          cursor: pointer;
          align-items: center;
          gap: calc(0.25rem * 2);
          &:hover {
            @media (hover: hover) {
              text-decoration-line: underline;
            }
          }
          &:focus {
            --tw-outline-style: none;
            outline-style: none;
            @media (forced-colors: active) {
              outline: 2px solid transparent;
              outline-offset: 2px;
            }
          }
          &:focus-visible {
            outline: 2px solid currentColor;
            outline-offset: 2px;
          }
        }
        & + *:before {
          content: "";
          margin-right: calc(0.25rem * 3);
          margin-left: calc(0.25rem * 2);
          display: block;
          height: calc(0.25rem * 1.5);
          width: calc(0.25rem * 1.5);
          opacity: 40%;
          rotate: 45deg;
          border-top: 1px solid;
          border-right: 1px solid;
          background-color: #0000;
        }
        [dir="rtl"] & + *:before {
          rotate: -135deg;
        }
      }
    }
  }
  .mr-1 {
    margin-right: calc(var(--spacing) * 1);
  }
  .mr-1\.5 {
    margin-right: calc(var(--spacing) * 1.5);
  }
  .mr-2 {
    margin-right: calc(var(--spacing) * 2);
  }
  .mr-2\.5 {
    margin-right: calc(var(--spacing) * 2.5);
  }
  .mr-3 {
    margin-right: calc(var(--spacing) * 3);
  }
  .mr-4 {
    margin-right: calc(var(--spacing) * 4);
  }
  .fieldset-legend {
    margin-bottom: calc(0.25rem * -1);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: calc(0.25rem * 2);
    padding-block: calc(0.25rem * 2);
    color: var(--color-base-content);
    font-weight: 600;
  }
  .footer-title {
    margin-bottom: calc(0.25rem * 2);
    text-transform: uppercase;
    opacity: 60%;
    font-weight: 600;
  }
  .mb-0\.5 {
    margin-bottom: calc(var(--spacing) * 0.5);
  }
  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }
  .mb-1\.5 {
    margin-bottom: calc(var(--spacing) * 1.5);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-2\.5 {
    margin-bottom: calc(var(--spacing) * 2.5);
  }
  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }
  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }
  .mb-5 {
    margin-bottom: calc(var(--spacing) * 5);
  }
  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }
  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }
  .mb-10 {
    margin-bottom: calc(var(--spacing) * 10);
  }
  .mb-12 {
    margin-bottom: calc(var(--spacing) * 12);
  }
  .mb-14 {
    margin-bottom: calc(var(--spacing) * 14);
  }
  .mb-16 {
    margin-bottom: calc(var(--spacing) * 16);
  }
  .-ml-1 {
    margin-left: calc(var(--spacing) * -1);
  }
  .ml-0\.5 {
    margin-left: calc(var(--spacing) * 0.5);
  }
  .ml-1 {
    margin-left: calc(var(--spacing) * 1);
  }
  .ml-1\.5 {
    margin-left: calc(var(--spacing) * 1.5);
  }
  .ml-2 {
    margin-left: calc(var(--spacing) * 2);
  }
  .ml-3 {
    margin-left: calc(var(--spacing) * 3);
  }
  .ml-4 {
    margin-left: calc(var(--spacing) * 4);
  }
  .ml-8 {
    margin-left: calc(var(--spacing) * 8);
  }
  .carousel-item {
    box-sizing: content-box;
    display: flex;
    flex: none;
    scroll-snap-align: start;
  }
  .status {
    display: inline-block;
    aspect-ratio: 1 / 1;
    width: calc(0.25rem * 2);
    height: calc(0.25rem * 2);
    border-radius: var(--radius-selector);
    background-color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-base-content) 20%, transparent);
    }
    background-position: center;
    background-repeat: no-repeat;
    vertical-align: middle;
    color: color-mix(in srgb, #000 30%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-black) 30%, transparent);
    }
    background-image: radial-gradient( circle at 35% 30%, oklch(1 0 0 / calc(var(--depth) * 0.5)), #0000 );
    box-shadow: 0 2px 3px -1px currentColor;
    @supports (color: color-mix(in lab, red, red)) {
      box-shadow: 0 2px 3px -1px color-mix(in oklab, currentColor calc(var(--depth) * 100%), #0000);
    }
  }
  .badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: calc(0.25rem * 2);
    border-radius: var(--radius-selector);
    vertical-align: middle;
    color: var(--badge-fg);
    border: var(--border) solid var(--badge-color, var(--color-base-200));
    font-size: 0.875rem;
    width: fit-content;
    padding-inline: calc(0.25rem * 3 - var(--border));
    background-size: auto, calc(var(--noise) * 100%);
    background-image: none, var(--fx-noise);
    background-color: var(--badge-bg);
    --badge-bg: var(--badge-color, var(--color-base-100));
    --badge-fg: var(--color-base-content);
    --size: calc(var(--size-selector, 0.25rem) * 6);
    height: var(--size);
    &.badge-outline {
      --badge-fg: var(--badge-color);
      --badge-bg: #0000;
      background-image: none;
    }
    &.badge-dash {
      --badge-fg: var(--badge-color);
      --badge-bg: #0000;
      border-style: dashed;
      background-image: none;
    }
    &.badge-soft {
      color: var(--badge-color, var(--color-base-content));
      background-color: var(--badge-color, var(--color-base-content));
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix( in oklab, var(--badge-color, var(--color-base-content)) 8%, var(--color-base-100) );
      }
      border-color: var(--badge-color, var(--color-base-content));
      @supports (color: color-mix(in lab, red, red)) {
        border-color: color-mix( in oklab, var(--badge-color, var(--color-base-content)) 10%, var(--color-base-100) );
      }
      background-image: none;
    }
  }
  .hero-arrow-path {
    --hero-arrow-path: url('data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20fill%3D%22none%22%20viewBox%3D%220%200%2024%2024%22%20stroke-width%3D%221.5%22%20stroke%3D%22currentColor%22%20aria-hidden%3D%22true%22%20data-slot%3D%22icon%22%3E%20%20%3Cpath%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20d%3D%22M16.023%209.348h4.992v-.001M2.985%2019.644v-4.992m0%200h4.992m-4.993%200%203.181%203.183a8.25%208.25%200%200%200%2013.803-3.7M4.031%209.865a8.25%208.25%200%200%201%2013.803-3.7l3.181%203.182m0-4.991v4.99%22%2F%3E%3C%2Fsvg%3E');
    -webkit-mask: var(--hero-arrow-path);
    mask: var(--hero-arrow-path);
    mask-repeat: no-repeat;
    background-color: currentColor;
    vertical-align: middle;
    display: inline-block;
    width: 1.5rem;
    height: 1.5rem;
  }
  .hero-computer-desktop-micro {
    --hero-computer-desktop-micro: url('data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016%2016%22%20fill%3D%22currentColor%22%20aria-hidden%3D%22true%22%20data-slot%3D%22icon%22%3E%20%20%3Cpath%20fill-rule%3D%22evenodd%22%20d%3D%22M2%204.25A2.25%202.25%200%200%201%204.25%202h7.5A2.25%202.25%200%200%201%2014%204.25v5.5A2.25%202.25%200%200%201%2011.75%2012h-1.312c.1.128.21.248.328.36a.75.75%200%200%201%20.234.545v.345a.75.75%200%200%201-.75.75h-4.5a.75.75%200%200%201-.75-.75v-.345a.75.75%200%200%201%20.234-.545c.118-.111.228-.232.328-.36H4.25A2.25%202.25%200%200%201%202%209.75v-5.5Zm2.25-.75a.75.75%200%200%200-.75.75v4.5c0%20.414.336.75.75.75h7.5a.75.75%200%200%200%20.75-.75v-4.5a.75.75%200%200%200-.75-.75h-7.5Z%22%20clip-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E');
    -webkit-mask: var(--hero-computer-desktop-micro);
    mask: var(--hero-computer-desktop-micro);
    mask-repeat: no-repeat;
    background-color: currentColor;
    vertical-align: middle;
    display: inline-block;
    width: 1rem;
    height: 1rem;
  }
  .hero-exclamation-circle-mini {
    --hero-exclamation-circle-mini: url('data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2020%2020%22%20fill%3D%22currentColor%22%20aria-hidden%3D%22true%22%20data-slot%3D%22icon%22%3E%20%20%3Cpath%20fill-rule%3D%22evenodd%22%20d%3D%22M18%2010a8%208%200%201%201-16%200%208%208%200%200%201%2016%200Zm-8-5a.75.75%200%200%201%20.75.75v4.5a.75.75%200%200%201-1.5%200v-4.5A.75.75%200%200%201%2010%205Zm0%2010a1%201%200%201%200%200-2%201%201%200%200%200%200%202Z%22%20clip-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E');
    -webkit-mask: var(--hero-exclamation-circle-mini);
    mask: var(--hero-exclamation-circle-mini);
    mask-repeat: no-repeat;
    background-color: currentColor;
    vertical-align: middle;
    display: inline-block;
    width: 1.25rem;
    height: 1.25rem;
  }
  .hero-information-circle-mini {
    --hero-information-circle-mini: url('data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2020%2020%22%20fill%3D%22currentColor%22%20aria-hidden%3D%22true%22%20data-slot%3D%22icon%22%3E%20%20%3Cpath%20fill-rule%3D%22evenodd%22%20d%3D%22M18%2010a8%208%200%201%201-16%200%208%208%200%200%201%2016%200Zm-7-4a1%201%200%201%201-2%200%201%201%200%200%201%202%200ZM9%209a.75.75%200%200%200%200%201.5h.253a.25.25%200%200%201%20.244.304l-.459%202.066A1.75%201.75%200%200%200%2010.747%2015H11a.75.75%200%200%200%200-1.5h-.253a.25.25%200%200%201-.244-.304l.459-2.066A1.75%201.75%200%200%200%209.253%209H9Z%22%20clip-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E');
    -webkit-mask: var(--hero-information-circle-mini);
    mask: var(--hero-information-circle-mini);
    mask-repeat: no-repeat;
    background-color: currentColor;
    vertical-align: middle;
    display: inline-block;
    width: 1.25rem;
    height: 1.25rem;
  }
  .hero-moon-micro {
    --hero-moon-micro: url('data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016%2016%22%20fill%3D%22currentColor%22%20aria-hidden%3D%22true%22%20data-slot%3D%22icon%22%3E%20%20%3Cpath%20d%3D%22M14.438%2010.148c.19-.425-.321-.787-.748-.601A5.5%205.5%200%200%201%206.453%202.31c.186-.427-.176-.938-.6-.748a6.501%206.501%200%201%200%208.585%208.586Z%22%2F%3E%3C%2Fsvg%3E');
    -webkit-mask: var(--hero-moon-micro);
    mask: var(--hero-moon-micro);
    mask-repeat: no-repeat;
    background-color: currentColor;
    vertical-align: middle;
    display: inline-block;
    width: 1rem;
    height: 1rem;
  }
  .hero-sun-micro {
    --hero-sun-micro: url('data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2016%2016%22%20fill%3D%22currentColor%22%20aria-hidden%3D%22true%22%20data-slot%3D%22icon%22%3E%20%20%3Cpath%20d%3D%22M8%201a.75.75%200%200%201%20.75.75v1.5a.75.75%200%200%201-1.5%200v-1.5A.75.75%200%200%201%208%201ZM10.5%208a2.5%202.5%200%201%201-5%200%202.5%202.5%200%200%201%205%200ZM12.95%204.11a.75.75%200%201%200-1.06-1.06l-1.062%201.06a.75.75%200%200%200%201.061%201.062l1.06-1.061ZM15%208a.75.75%200%200%201-.75.75h-1.5a.75.75%200%200%201%200-1.5h1.5A.75.75%200%200%201%2015%208ZM11.89%2012.95a.75.75%200%200%200%201.06-1.06l-1.06-1.062a.75.75%200%200%200-1.062%201.061l1.061%201.06ZM8%2012a.75.75%200%200%201%20.75.75v1.5a.75.75%200%200%201-1.5%200v-1.5A.75.75%200%200%201%208%2012ZM5.172%2011.89a.75.75%200%200%200-1.061-1.062L3.05%2011.89a.75.75%200%201%200%201.06%201.06l1.06-1.06ZM4%208a.75.75%200%200%201-.75.75h-1.5a.75.75%200%200%201%200-1.5h1.5A.75.75%200%200%201%204%208ZM4.11%205.172A.75.75%200%200%200%205.173%204.11L4.11%203.05a.75.75%200%201%200-1.06%201.06l1.06%201.06Z%22%2F%3E%3C%2Fsvg%3E');
    -webkit-mask: var(--hero-sun-micro);
    mask: var(--hero-sun-micro);
    mask-repeat: no-repeat;
    background-color: currentColor;
    vertical-align: middle;
    display: inline-block;
    width: 1rem;
    height: 1rem;
  }
  .hero-x-mark-solid {
    --hero-x-mark-solid: url('data:image/svg+xml;utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22currentColor%22%20aria-hidden%3D%22true%22%20data-slot%3D%22icon%22%3E%20%20%3Cpath%20fill-rule%3D%22evenodd%22%20d%3D%22M5.47%205.47a.75.75%200%200%201%201.06%200L12%2010.94l5.47-5.47a.75.75%200%201%201%201.06%201.06L13.06%2012l5.47%205.47a.75.75%200%201%201-1.06%201.06L12%2013.06l-5.47%205.47a.75.75%200%200%201-1.06-1.06L10.94%2012%205.47%206.53a.75.75%200%200%201%200-1.06Z%22%20clip-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E');
    -webkit-mask: var(--hero-x-mark-solid);
    mask: var(--hero-x-mark-solid);
    mask-repeat: no-repeat;
    background-color: currentColor;
    vertical-align: middle;
    display: inline-block;
    width: 1.5rem;
    height: 1.5rem;
  }
  .kbd {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-field);
    background-color: var(--color-base-200);
    vertical-align: middle;
    padding-left: 0.5em;
    padding-right: 0.5em;
    border: var(--border) solid var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      border: var(--border) solid color-mix(in srgb, var(--color-base-content) 20%, #0000);
    }
    border-bottom: calc(var(--border) + 1px) solid var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      border-bottom: calc(var(--border) + 1px) solid color-mix(in srgb, var(--color-base-content) 20%, #0000);
    }
    --size: calc(var(--size-selector, 0.25rem) * 6);
    font-size: 0.875rem;
    height: var(--size);
    min-width: var(--size);
  }
  .tabs {
    display: flex;
    flex-wrap: wrap;
    --tabs-height: auto;
    --tabs-direction: row;
    height: var(--tabs-height);
    flex-direction: var(--tabs-direction);
  }
  .navbar {
    display: flex;
    width: 100%;
    align-items: center;
    padding: 0.5rem;
    min-height: 4rem;
  }
  .footer {
    display: grid;
    width: 100%;
    grid-auto-flow: row;
    place-items: start;
    column-gap: calc(0.25rem * 4);
    row-gap: calc(0.25rem * 10);
    font-size: 0.875rem;
    line-height: 1.25rem;
    & > * {
      display: grid;
      place-items: start;
      gap: calc(0.25rem * 2);
    }
    &.footer-center {
      grid-auto-flow: column dense;
      place-items: center;
      text-align: center;
      & > * {
        place-items: center;
      }
    }
  }
  .stat {
    display: inline-grid;
    width: 100%;
    column-gap: calc(0.25rem * 4);
    padding-inline: calc(0.25rem * 6);
    padding-block: calc(0.25rem * 4);
    grid-template-columns: repeat(1, 1fr);
    &:not(:last-child) {
      border-inline-end: var(--border) dashed currentColor;
      @supports (color: color-mix(in lab, red, red)) {
        border-inline-end: var(--border) dashed color-mix(in oklab, currentColor 10%, #0000);
      }
      border-block-end: none;
    }
  }
  .navbar-end {
    display: inline-flex;
    align-items: center;
    width: 50%;
    justify-content: flex-end;
  }
  .navbar-start {
    display: inline-flex;
    align-items: center;
    width: 50%;
    justify-content: flex-start;
  }
  .card-body {
    display: flex;
    flex: auto;
    flex-direction: column;
    gap: calc(0.25rem * 2);
    padding: var(--card-p, 1.5rem);
    font-size: var(--card-fs, 0.875rem);
    :where(p) {
      flex-grow: 1;
    }
  }
  .navbar-center {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
  }
  .fieldset-label {
    display: flex;
    align-items: center;
    gap: calc(0.25rem * 1.5);
    color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-base-content) 60%, transparent);
    }
    &:has(input) {
      cursor: pointer;
    }
  }
  .carousel {
    display: inline-flex;
    overflow-x: scroll;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    &::-webkit-scrollbar {
      display: none;
    }
  }
  .alert {
    display: grid;
    align-items: center;
    gap: calc(0.25rem * 4);
    border-radius: var(--radius-box);
    padding-inline: calc(0.25rem * 4);
    padding-block: calc(0.25rem * 3);
    color: var(--color-base-content);
    background-color: var(--alert-color, var(--color-base-200));
    justify-content: start;
    justify-items: start;
    grid-auto-flow: column;
    grid-template-columns: auto;
    text-align: start;
    border: var(--border) solid var(--color-base-200);
    font-size: 0.875rem;
    line-height: 1.25rem;
    background-size: auto, calc(var(--noise) * 100%);
    background-image: none, var(--fx-noise);
    box-shadow: 0 3px 0 -2px oklch(100% 0 0 / calc(var(--depth) * 0.08)) inset, 0 1px #000, 0 4px 3px -2px oklch(0% 0 0 / calc(var(--depth) * 0.08));
    @supports (color: color-mix(in lab, red, red)) {
      box-shadow: 0 3px 0 -2px oklch(100% 0 0 / calc(var(--depth) * 0.08)) inset, 0 1px color-mix( in oklab, color-mix(in oklab, #000 20%, var(--alert-color, var(--color-base-200))) calc(var(--depth) * 20%), #0000 ), 0 4px 3px -2px oklch(0% 0 0 / calc(var(--depth) * 0.08));
    }
    &:has(:nth-child(2)) {
      grid-template-columns: auto minmax(auto, 1fr);
    }
    &.alert-outline {
      background-color: transparent;
      color: var(--alert-color);
      box-shadow: none;
      background-image: none;
    }
    &.alert-dash {
      background-color: transparent;
      color: var(--alert-color);
      border-style: dashed;
      box-shadow: none;
      background-image: none;
    }
    &.alert-soft {
      color: var(--alert-color, var(--color-base-content));
      background: var(--alert-color, var(--color-base-content));
      @supports (color: color-mix(in lab, red, red)) {
        background: color-mix( in oklab, var(--alert-color, var(--color-base-content)) 8%, var(--color-base-100) );
      }
      border-color: var(--alert-color, var(--color-base-content));
      @supports (color: color-mix(in lab, red, red)) {
        border-color: color-mix( in oklab, var(--alert-color, var(--color-base-content)) 10%, var(--color-base-100) );
      }
      box-shadow: none;
      background-image: none;
    }
  }
  .fieldset {
    display: grid;
    gap: calc(0.25rem * 1.5);
    padding-block: calc(0.25rem * 1);
    font-size: 0.75rem;
    grid-template-columns: 1fr;
    grid-auto-rows: max-content;
  }
  .card-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: calc(0.25rem * 2);
  }
  .avatar-placeholder {
    & > div {
      display: flex;
      align-items: center;
      justify-content: center;
    }
  }
  .card-title {
    display: flex;
    align-items: center;
    gap: calc(0.25rem * 2);
    font-size: var(--cardtitle-fs, 1.125rem);
    font-weight: 600;
  }
  .join {
    display: inline-flex;
    align-items: stretch;
    --join-ss: 0;
    --join-se: 0;
    --join-es: 0;
    --join-ee: 0;
    :where(.join-item) {
      border-start-start-radius: var(--join-ss, 0);
      border-start-end-radius: var(--join-se, 0);
      border-end-start-radius: var(--join-es, 0);
      border-end-end-radius: var(--join-ee, 0);
      * {
        --join-ss: var(--radius-field);
        --join-se: var(--radius-field);
        --join-es: var(--radius-field);
        --join-ee: var(--radius-field);
      }
    }
    > .join-item:where(:first-child) {
      --join-ss: var(--radius-field);
      --join-se: 0;
      --join-es: var(--radius-field);
      --join-ee: 0;
    }
    :first-child:not(:last-child) {
      :where(.join-item) {
        --join-ss: var(--radius-field);
        --join-se: 0;
        --join-es: var(--radius-field);
        --join-ee: 0;
      }
    }
    > .join-item:where(:last-child) {
      --join-ss: 0;
      --join-se: var(--radius-field);
      --join-es: 0;
      --join-ee: var(--radius-field);
    }
    :last-child:not(:first-child) {
      :where(.join-item) {
        --join-ss: 0;
        --join-se: var(--radius-field);
        --join-es: 0;
        --join-ee: var(--radius-field);
      }
    }
    > .join-item:where(:only-child) {
      --join-ss: var(--radius-field);
      --join-se: var(--radius-field);
      --join-es: var(--radius-field);
      --join-ee: var(--radius-field);
    }
    :only-child {
      :where(.join-item) {
        --join-ss: var(--radius-field);
        --join-se: var(--radius-field);
        --join-es: var(--radius-field);
        --join-ee: var(--radius-field);
      }
    }
  }
  .join\! {
    display: inline-flex !important;
    align-items: stretch !important;
    --join-ss: 0 !important;
    --join-se: 0 !important;
    --join-es: 0 !important;
    --join-ee: 0 !important;
    :where(.join-item) {
      border-start-start-radius: var(--join-ss, 0) !important;
      border-start-end-radius: var(--join-se, 0) !important;
      border-end-start-radius: var(--join-es, 0) !important;
      border-end-end-radius: var(--join-ee, 0) !important;
      * {
        --join-ss: var(--radius-field) !important;
        --join-se: var(--radius-field) !important;
        --join-es: var(--radius-field) !important;
        --join-ee: var(--radius-field) !important;
      }
    }
    > .join-item:where(:first-child) {
      --join-ss: var(--radius-field) !important;
      --join-se: 0 !important;
      --join-es: var(--radius-field) !important;
      --join-ee: 0 !important;
    }
    :first-child:not(:last-child) {
      :where(.join-item) {
        --join-ss: var(--radius-field) !important;
        --join-se: 0 !important;
        --join-es: var(--radius-field) !important;
        --join-ee: 0 !important;
      }
    }
    > .join-item:where(:last-child) {
      --join-ss: 0 !important;
      --join-se: var(--radius-field) !important;
      --join-es: 0 !important;
      --join-ee: var(--radius-field) !important;
    }
    :last-child:not(:first-child) {
      :where(.join-item) {
        --join-ss: 0 !important;
        --join-se: var(--radius-field) !important;
        --join-es: 0 !important;
        --join-ee: var(--radius-field) !important;
      }
    }
    > .join-item:where(:only-child) {
      --join-ss: var(--radius-field) !important;
      --join-se: var(--radius-field) !important;
      --join-es: var(--radius-field) !important;
      --join-ee: var(--radius-field) !important;
    }
    :only-child {
      :where(.join-item) {
        --join-ss: var(--radius-field) !important;
        --join-se: var(--radius-field) !important;
        --join-es: var(--radius-field) !important;
        --join-ee: var(--radius-field) !important;
      }
    }
  }
  .mockup-phone {
    display: inline-grid;
    justify-items: center;
    border: 6px solid #6b6b6b;
    border-radius: 65px;
    background-color: #000;
    padding: 11px;
    overflow: hidden;
  }
  .chat {
    display: grid;
    column-gap: calc(0.25rem * 3);
    padding-block: calc(0.25rem * 1);
  }
  .chat\! {
    display: grid !important;
    column-gap: calc(0.25rem * 3) !important;
    padding-block: calc(0.25rem * 1) !important;
  }
  .avatar-group {
    display: flex;
    overflow: hidden;
    :where(.avatar) {
      overflow: hidden;
      border-radius: calc(infinity * 1px);
      border: 4px solid var(--color-base-100);
    }
  }
  .line-clamp-2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  .line-clamp-3 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
  }
  .prose {
    :root & {
      --tw-prose-body: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-prose-body: color-mix(in oklab, var(--color-base-content) 80%, #0000);
      }
      --tw-prose-headings: var(--color-base-content);
      --tw-prose-lead: var(--color-base-content);
      --tw-prose-links: var(--color-base-content);
      --tw-prose-bold: var(--color-base-content);
      --tw-prose-counters: var(--color-base-content);
      --tw-prose-bullets: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-prose-bullets: color-mix(in oklab, var(--color-base-content) 50%, #0000);
      }
      --tw-prose-hr: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-prose-hr: color-mix(in oklab, var(--color-base-content) 20%, #0000);
      }
      --tw-prose-quotes: var(--color-base-content);
      --tw-prose-quote-borders: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-prose-quote-borders: color-mix(in oklab, var(--color-base-content) 20%, #0000);
      }
      --tw-prose-captions: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-prose-captions: color-mix(in oklab, var(--color-base-content) 50%, #0000);
      }
      --tw-prose-code: var(--color-base-content);
      --tw-prose-pre-code: var(--color-neutral-content);
      --tw-prose-pre-bg: var(--color-neutral);
      --tw-prose-th-borders: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-prose-th-borders: color-mix(in oklab, var(--color-base-content) 50%, #0000);
      }
      --tw-prose-td-borders: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-prose-td-borders: color-mix(in oklab, var(--color-base-content) 20%, #0000);
      }
      --tw-prose-kbd: var(--color-base-content);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-prose-kbd: color-mix(in oklab, var(--color-base-content) 80%, #0000);
      }
      :where(code):not(pre > code) {
        background-color: var(--color-base-200);
        border-radius: var(--radius-selector);
        border: var(--border) solid var(--color-base-300);
        padding-inline: 0.5em;
        font-weight: inherit;
        &:before, &:after {
          display: none;
        }
      }
    }
  }
  .mask {
    display: inline-block;
    vertical-align: middle;
    mask-size: contain;
    mask-repeat: no-repeat;
    mask-position: center;
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline {
    display: inline;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .inline-grid {
    display: inline-grid;
  }
  .table {
    display: table;
  }
  .aspect-\[16\/9\] {
    aspect-ratio: 16/9;
  }
  .aspect-square {
    aspect-ratio: 1 / 1;
  }
  .modal-bottom {
    place-items: end;
    :where(.modal-box) {
      height: auto;
      width: 100%;
      max-width: none;
      max-height: calc(100vh - 5em);
      translate: 0 100%;
      scale: 1;
      --modal-tl: var(--radius-box);
      --modal-tr: var(--radius-box);
      --modal-bl: 0;
      --modal-br: 0;
    }
  }
  .modal-end {
    place-items: end;
    :where(.modal-box) {
      height: 100vh;
      max-height: none;
      width: auto;
      max-width: none;
      translate: 100% 0;
      scale: 1;
      --modal-tl: var(--radius-box);
      --modal-tr: 0;
      --modal-bl: var(--radius-box);
      --modal-br: 0;
    }
  }
  .modal-middle {
    place-items: center;
    :where(.modal-box) {
      height: auto;
      width: calc(11/12 * 100%);
      max-width: 32rem;
      max-height: calc(100vh - 5em);
      translate: 0 2%;
      scale: 98%;
      --modal-tl: var(--radius-box);
      --modal-tr: var(--radius-box);
      --modal-bl: var(--radius-box);
      --modal-br: var(--radius-box);
    }
  }
  .modal-start {
    place-items: start;
    :where(.modal-box) {
      height: 100vh;
      max-height: none;
      width: auto;
      max-width: none;
      translate: -100% 0;
      scale: 1;
      --modal-tl: 0;
      --modal-tr: var(--radius-box);
      --modal-bl: 0;
      --modal-br: var(--radius-box);
    }
  }
  .modal-top {
    place-items: start;
    :where(.modal-box) {
      height: auto;
      width: 100%;
      max-width: none;
      max-height: calc(100vh - 5em);
      translate: 0 -100%;
      scale: 1;
      --modal-tl: 0;
      --modal-tr: 0;
      --modal-bl: var(--radius-box);
      --modal-br: var(--radius-box);
    }
  }
  .card-side {
    align-items: stretch;
    flex-direction: row;
    :where(figure:first-child) {
      overflow: hidden;
      border-start-start-radius: inherit;
      border-start-end-radius: unset;
      border-end-start-radius: inherit;
      border-end-end-radius: unset;
    }
    :where(figure:last-child) {
      overflow: hidden;
      border-start-start-radius: unset;
      border-start-end-radius: inherit;
      border-end-start-radius: unset;
      border-end-end-radius: inherit;
    }
    figure > * {
      max-width: unset;
    }
    :where(figure > *) {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
  }
  .divider-horizontal {
    --divider-m: 0 1rem;
    &.divider {
      height: auto;
      width: calc(0.25rem * 4);
      flex-direction: column;
      &:before {
        height: 100%;
        width: calc(0.25rem * 0.5);
      }
      &:after {
        height: 100%;
        width: calc(0.25rem * 0.5);
      }
    }
  }
  .divider-vertical {
    --divider-m: 1rem 0;
    &.divider {
      height: calc(0.25rem * 4);
      width: auto;
      flex-direction: row;
      &:before {
        height: calc(0.25rem * 0.5);
        width: 100%;
      }
      &:after {
        height: calc(0.25rem * 0.5);
        width: 100%;
      }
    }
  }
  .btn-circle {
    border-radius: calc(infinity * 1px);
    padding-inline: calc(0.25rem * 0);
    width: var(--size);
    height: var(--size);
  }
  .btn-square {
    padding-inline: calc(0.25rem * 0);
    width: var(--size);
    height: var(--size);
  }
  .size-3 {
    width: calc(var(--spacing) * 3);
    height: calc(var(--spacing) * 3);
  }
  .size-4 {
    width: calc(var(--spacing) * 4);
    height: calc(var(--spacing) * 4);
  }
  .size-5 {
    width: calc(var(--spacing) * 5);
    height: calc(var(--spacing) * 5);
  }
  .status-lg {
    width: calc(0.25rem * 3);
    height: calc(0.25rem * 3);
  }
  .status-md {
    width: calc(0.25rem * 2);
    height: calc(0.25rem * 2);
  }
  .status-sm {
    width: calc(0.25rem * 1);
    height: calc(0.25rem * 1);
  }
  .status-xl {
    width: calc(0.25rem * 4);
    height: calc(0.25rem * 4);
  }
  .status-xs {
    width: calc(0.25rem * 0.5);
    height: calc(0.25rem * 0.5);
  }
  .tabs-lg {
    :where(.tab) {
      height: calc(var(--size-field, 0.25rem) * 12);
      font-size: 1.125rem;
      --tab-p: 1rem;
      --tab-radius-min: calc(1.5rem - var(--border));
    }
  }
  .tabs-md {
    :where(.tab) {
      height: calc(var(--size-field, 0.25rem) * 10);
      font-size: 0.875rem;
      --tab-p: 0.75rem;
      --tab-radius-min: calc(0.75rem - var(--border));
    }
  }
  .tabs-sm {
    :where(.tab) {
      height: calc(var(--size-field, 0.25rem) * 8);
      font-size: 0.875rem;
      --tab-p: 0.5rem;
      --tab-radius-min: calc(0.5rem - var(--border));
    }
  }
  .tabs-xl {
    :where(.tab) {
      height: calc(var(--size-field, 0.25rem) * 14);
      font-size: 1.125rem;
      --tab-p: 1.25rem;
      --tab-radius-min: calc(2rem - var(--border));
    }
  }
  .tabs-xs {
    :where(.tab) {
      height: calc(var(--size-field, 0.25rem) * 6);
      font-size: 0.75rem;
      --tab-p: 0.375rem;
      --tab-radius-min: calc(0.5rem - var(--border));
    }
  }
  .dock-md {
    height: 4rem;
    height: calc(4rem + env(safe-area-inset-bottom));
    .dock-label {
      font-size: 0.6875rem;
    }
  }
  .h-1 {
    height: calc(var(--spacing) * 1);
  }
  .h-1\.5 {
    height: calc(var(--spacing) * 1.5);
  }
  .h-2 {
    height: calc(var(--spacing) * 2);
  }
  .h-3 {
    height: calc(var(--spacing) * 3);
  }
  .h-3\.5 {
    height: calc(var(--spacing) * 3.5);
  }
  .h-4 {
    height: calc(var(--spacing) * 4);
  }
  .h-4\.5 {
    height: calc(var(--spacing) * 4.5);
  }
  .h-5 {
    height: calc(var(--spacing) * 5);
  }
  .h-6 {
    height: calc(var(--spacing) * 6);
  }
  .h-7 {
    height: calc(var(--spacing) * 7);
  }
  .h-8 {
    height: calc(var(--spacing) * 8);
  }
  .h-9 {
    height: calc(var(--spacing) * 9);
  }
  .h-10 {
    height: calc(var(--spacing) * 10);
  }
  .h-11 {
    height: calc(var(--spacing) * 11);
  }
  .h-12 {
    height: calc(var(--spacing) * 12);
  }
  .h-14 {
    height: calc(var(--spacing) * 14);
  }
  .h-16 {
    height: calc(var(--spacing) * 16);
  }
  .h-20 {
    height: calc(var(--spacing) * 20);
  }
  .h-24 {
    height: calc(var(--spacing) * 24);
  }
  .h-32 {
    height: calc(var(--spacing) * 32);
  }
  .h-48 {
    height: calc(var(--spacing) * 48);
  }
  .h-\[18px\] {
    height: 18px;
  }
  .h-\[40vh\] {
    height: 40vh;
  }
  .h-\[45vh\] {
    height: 45vh;
  }
  .h-\[56px\] {
    height: 56px;
  }
  .h-\[60px\] {
    height: 60px;
  }
  .h-auto {
    height: auto;
  }
  .h-full {
    height: 100%;
  }
  .h-px {
    height: 1px;
  }
  .h-screen {
    height: 100vh;
  }
  .max-h-48 {
    max-height: calc(var(--spacing) * 48);
  }
  .max-h-80 {
    max-height: calc(var(--spacing) * 80);
  }
  .max-h-96 {
    max-height: calc(var(--spacing) * 96);
  }
  .max-h-\[85vh\] {
    max-height: 85vh;
  }
  .max-h-\[90vh\] {
    max-height: 90vh;
  }
  .max-h-\[calc\(85vh-48px\)\] {
    max-height: calc(85vh - 48px);
  }
  .max-h-screen {
    max-height: 100vh;
  }
  .min-h-0 {
    min-height: calc(var(--spacing) * 0);
  }
  .min-h-7 {
    min-height: calc(var(--spacing) * 7);
  }
  .min-h-64 {
    min-height: calc(var(--spacing) * 64);
  }
  .min-h-\[20px\] {
    min-height: 20px;
  }
  .min-h-\[40px\] {
    min-height: 40px;
  }
  .min-h-\[44px\] {
    min-height: 44px;
  }
  .min-h-\[48px\] {
    min-height: 48px;
  }
  .min-h-\[calc\(100vh-56px\)\] {
    min-height: calc(100vh - 56px);
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .btn-wide {
    width: 100%;
    max-width: calc(0.25rem * 64);
  }
  .cally {
    font-size: 0.7rem;
    &::part(container) {
      padding: 0.5rem 1rem;
      user-select: none;
    }
    ::part(th) {
      font-weight: normal;
      block-size: auto;
    }
    &::part(header) {
      direction: ltr;
    }
    ::part(head) {
      opacity: 0.5;
      font-size: 0.7rem;
    }
    &::part(button) {
      border-radius: var(--radius-field);
      border: none;
      padding: 0.5rem;
      background: #0000;
    }
    &::part(button):hover {
      background: var(--color-base-200);
    }
    ::part(day) {
      border-radius: var(--radius-field);
      font-size: 0.7rem;
    }
    ::part(button day today) {
      background: var(--color-primary);
      color: var(--color-primary-content);
    }
    ::part(selected) {
      color: var(--color-base-100);
      background: var(--color-base-content);
      border-radius: var(--radius-field);
    }
    ::part(range-inner) {
      border-radius: 0;
    }
    ::part(range-start) {
      border-start-end-radius: 0;
      border-end-end-radius: 0;
    }
    ::part(range-end) {
      border-start-start-radius: 0;
      border-end-start-radius: 0;
    }
    ::part(range-start range-end) {
      border-radius: var(--radius-field);
    }
    calendar-month {
      width: 100%;
    }
  }
  .rating-half {
    :where(*:not(.rating-hidden)) {
      width: calc(0.25rem * 3);
    }
    &.rating-xs *:not(.rating-hidden) {
      width: calc(0.25rem * 2);
    }
    &.rating-sm *:not(.rating-hidden) {
      width: calc(0.25rem * 2.5);
    }
    &.rating-md *:not(.rating-hidden) {
      width: calc(0.25rem * 3);
    }
    &.rating-lg *:not(.rating-hidden) {
      width: .875rem;
    }
    &.rating-xl *:not(.rating-hidden) {
      width: calc(0.25rem * 4);
    }
  }
  .btn-block {
    width: 100%;
  }
  .loading-lg {
    width: calc(var(--size-selector, 0.25rem) * 7);
  }
  .loading-md {
    width: calc(var(--size-selector, 0.25rem) * 6);
  }
  .loading-sm {
    width: calc(var(--size-selector, 0.25rem) * 5);
  }
  .loading-xl {
    width: calc(var(--size-selector, 0.25rem) * 8);
  }
  .loading-xs {
    width: calc(var(--size-selector, 0.25rem) * 4);
  }
  .w-0 {
    width: calc(var(--spacing) * 0);
  }
  .w-1 {
    width: calc(var(--spacing) * 1);
  }
  .w-1\.5 {
    width: calc(var(--spacing) * 1.5);
  }
  .w-2 {
    width: calc(var(--spacing) * 2);
  }
  .w-3 {
    width: calc(var(--spacing) * 3);
  }
  .w-3\.5 {
    width: calc(var(--spacing) * 3.5);
  }
  .w-4 {
    width: calc(var(--spacing) * 4);
  }
  .w-4\.5 {
    width: calc(var(--spacing) * 4.5);
  }
  .w-5 {
    width: calc(var(--spacing) * 5);
  }
  .w-6 {
    width: calc(var(--spacing) * 6);
  }
  .w-7 {
    width: calc(var(--spacing) * 7);
  }
  .w-8 {
    width: calc(var(--spacing) * 8);
  }
  .w-9 {
    width: calc(var(--spacing) * 9);
  }
  .w-10 {
    width: calc(var(--spacing) * 10);
  }
  .w-11 {
    width: calc(var(--spacing) * 11);
  }
  .w-12 {
    width: calc(var(--spacing) * 12);
  }
  .w-14 {
    width: calc(var(--spacing) * 14);
  }
  .w-16 {
    width: calc(var(--spacing) * 16);
  }
  .w-20 {
    width: calc(var(--spacing) * 20);
  }
  .w-24 {
    width: calc(var(--spacing) * 24);
  }
  .w-32 {
    width: calc(var(--spacing) * 32);
  }
  .w-48 {
    width: calc(var(--spacing) * 48);
  }
  .w-80 {
    width: calc(var(--spacing) * 80);
  }
  .w-\[33\%\] {
    width: 33%;
  }
  .w-\[280px\] {
    width: 280px;
  }
  .w-fit {
    width: fit-content;
  }
  .w-full {
    width: 100%;
  }
  .w-screen {
    width: 100vw;
  }
  .max-w-2xl {
    max-width: var(--container-2xl);
  }
  .max-w-3xl {
    max-width: var(--container-3xl);
  }
  .max-w-4xl {
    max-width: var(--container-4xl);
  }
  .max-w-5xl {
    max-width: var(--container-5xl);
  }
  .max-w-6xl {
    max-width: var(--container-6xl);
  }
  .max-w-7xl {
    max-width: var(--container-7xl);
  }
  .max-w-80 {
    max-width: calc(var(--spacing) * 80);
  }
  .max-w-\[80\%\] {
    max-width: 80%;
  }
  .max-w-\[85\%\] {
    max-width: 85%;
  }
  .max-w-\[260px\] {
    max-width: 260px;
  }
  .max-w-full {
    max-width: 100%;
  }
  .max-w-lg {
    max-width: var(--container-lg);
  }
  .max-w-md {
    max-width: var(--container-md);
  }
  .max-w-none {
    max-width: none;
  }
  .max-w-sm {
    max-width: var(--container-sm);
  }
  .max-w-xl {
    max-width: var(--container-xl);
  }
  .max-w-xs {
    max-width: var(--container-xs);
  }
  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }
  .min-w-\[18px\] {
    min-width: 18px;
  }
  .min-w-\[20px\] {
    min-width: 20px;
  }
  .min-w-\[40px\] {
    min-width: 40px;
  }
  .min-w-\[44px\] {
    min-width: 44px;
  }
  .min-w-\[48px\] {
    min-width: 48px;
  }
  .min-w-\[80px\] {
    min-width: 80px;
  }
  .min-w-\[200px\] {
    min-width: 200px;
  }
  .min-w-full {
    min-width: 100%;
  }
  .flex-1 {
    flex: 1;
  }
  .flex-\[2\] {
    flex: 2;
  }
  .flex-none {
    flex: none;
  }
  .flex-shrink {
    flex-shrink: 1;
  }
  .flex-shrink-0 {
    flex-shrink: 0;
  }
  .shrink-0 {
    flex-shrink: 0;
  }
  .flex-grow {
    flex-grow: 1;
  }
  .border-collapse {
    border-collapse: collapse;
  }
  .origin-top-right {
    transform-origin: top right;
  }
  .-translate-x-1\/2 {
    --tw-translate-x: calc(calc(1/2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .-translate-x-full {
    --tw-translate-x: -100%;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-x-0 {
    --tw-translate-x: calc(var(--spacing) * 0);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-x-1 {
    --tw-translate-x: calc(var(--spacing) * 1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-x-5 {
    --tw-translate-x: calc(var(--spacing) * 5);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-x-6 {
    --tw-translate-x: calc(var(--spacing) * 6);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .-translate-y-1\/2 {
    --tw-translate-y: calc(calc(1/2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-y-0 {
    --tw-translate-y: calc(var(--spacing) * 0);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-y-4 {
    --tw-translate-y: calc(var(--spacing) * 4);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .scale-95 {
    --tw-scale-x: 95%;
    --tw-scale-y: 95%;
    --tw-scale-z: 95%;
    scale: var(--tw-scale-x) var(--tw-scale-y);
  }
  .scale-100 {
    --tw-scale-x: 100%;
    --tw-scale-y: 100%;
    --tw-scale-z: 100%;
    scale: var(--tw-scale-x) var(--tw-scale-y);
  }
  .scale-110 {
    --tw-scale-x: 110%;
    --tw-scale-y: 110%;
    --tw-scale-z: 110%;
    scale: var(--tw-scale-x) var(--tw-scale-y);
  }
  .swap-rotate {
    .swap-on, input:indeterminate ~ .swap-on {
      rotate: 45deg;
    }
    input:is(:checked, :indeterminate) ~ .swap-on, &.swap-active .swap-on {
      rotate: 0deg;
    }
    input:is(:checked, :indeterminate) ~ .swap-off, &.swap-active .swap-off {
      rotate: calc(45deg * -1);
    }
  }
  .rotate-0 {
    rotate: 0deg;
  }
  .rotate-180 {
    rotate: 180deg;
  }
  .swap-flip {
    transform-style: preserve-3d;
    perspective: 20rem;
    .swap-on, .swap-indeterminate, input:indeterminate ~ .swap-on {
      transform: rotateY(180deg);
      backface-visibility: hidden;
      opacity: 100%;
    }
    input:is(:checked, :indeterminate) ~ .swap-on, &.swap-active .swap-on {
      transform: rotateY(0deg);
    }
    input:is(:checked, :indeterminate) ~ .swap-off, &.swap-active .swap-off {
      transform: rotateY(-180deg);
      backface-visibility: hidden;
      opacity: 100%;
    }
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .skeleton {
    border-radius: var(--radius-box);
    background-color: var(--color-base-300);
    @media (prefers-reduced-motion: reduce) {
      transition-duration: 15s;
    }
    will-change: background-position;
    animation: skeleton 1.8s ease-in-out infinite;
    background-image: linear-gradient( 105deg, #0000 0% 40%, var(--color-base-100) 50%, #0000 60% 100% );
    background-size: 200% auto;
    background-repeat: no-repeat;
    background-position-x: -50%;
  }
  .animate-bounce {
    animation: var(--animate-bounce);
  }
  .animate-bounce-in {
    animation: bounceIn 0.5s ease-in-out;
  }
  .animate-ping {
    animation: var(--animate-ping);
  }
  .animate-pulse {
    animation: var(--animate-pulse);
  }
  .animate-spin {
    animation: var(--animate-spin);
  }
  .animate-vote-twice {
    animation: pulse 1s ease-in 2;
  }
  .link {
    cursor: pointer;
    text-decoration-line: underline;
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
      @media (forced-colors: active) {
        outline: 2px solid transparent;
        outline-offset: 2px;
      }
    }
    &:focus-visible {
      outline: 2px solid currentColor;
      outline-offset: 2px;
    }
  }
  .cursor-not-allowed {
    cursor: not-allowed;
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .cursor-wait {
    cursor: wait;
  }
  .resize {
    resize: both;
  }
  .resize-none {
    resize: none;
  }
  .carousel-horizontal {
    flex-direction: row;
    overflow-x: scroll;
    scroll-snap-type: x mandatory;
  }
  .carousel-vertical {
    flex-direction: column;
    overflow-y: scroll;
    scroll-snap-type: y mandatory;
  }
  .carousel-center {
    .carousel-item {
      scroll-snap-align: center;
    }
  }
  .carousel-end {
    .carousel-item {
      scroll-snap-align: end;
    }
  }
  .carousel-start {
    .carousel-item {
      scroll-snap-align: start;
    }
  }
  .scroll-mt-20 {
    scroll-margin-top: calc(var(--spacing) * 20);
  }
  .list-disc {
    list-style-type: disc;
  }
  .list-none {
    list-style-type: none;
  }
  .alert-horizontal {
    justify-content: start;
    justify-items: start;
    grid-auto-flow: column;
    grid-template-columns: auto;
    text-align: start;
    &:has(:nth-child(2)) {
      grid-template-columns: auto minmax(auto, 1fr);
    }
  }
  .alert-vertical {
    justify-content: center;
    justify-items: center;
    grid-auto-flow: row;
    grid-template-columns: auto;
    text-align: center;
    &:has(:nth-child(2)) {
      grid-template-columns: auto;
    }
  }
  .stats-horizontal {
    grid-auto-flow: column;
    overflow-x: auto;
    .stat:not(:last-child) {
      border-inline-end: var(--border) dashed currentColor;
      @supports (color: color-mix(in lab, red, red)) {
        border-inline-end: var(--border) dashed color-mix(in oklab, currentColor 10%, #0000);
      }
      border-block-end: none;
    }
  }
  .stats-vertical {
    grid-auto-flow: row;
    overflow-y: auto;
    .stat:not(:last-child) {
      border-inline-end: none;
      border-block-end: var(--border) dashed currentColor;
      @supports (color: color-mix(in lab, red, red)) {
        border-block-end: var(--border) dashed color-mix(in oklab, currentColor 10%, #0000);
      }
    }
  }
  .footer-horizontal {
    grid-auto-flow: column;
    &.footer-center {
      grid-auto-flow: row dense;
    }
  }
  .footer-vertical {
    grid-auto-flow: row;
    &.footer-center {
      grid-auto-flow: column dense;
    }
  }
  .grid-cols-1 {
    grid-template-columns: repeat(1, 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-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .flex-col {
    flex-direction: column;
  }
  .flex-row {
    flex-direction: row;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-center {
    align-items: center;
  }
  .items-end {
    align-items: flex-end;
  }
  .items-start {
    align-items: flex-start;
  }
  .items-stretch {
    align-items: stretch;
  }
  .justify-around {
    justify-content: space-around;
  }
  .justify-baseline {
    justify-content: baseline;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .justify-end {
    justify-content: flex-end;
  }
  .justify-evenly {
    justify-content: space-evenly;
  }
  .justify-start {
    justify-content: flex-start;
  }
  .gap-0\.5 {
    gap: calc(var(--spacing) * 0.5);
  }
  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }
  .gap-1\.5 {
    gap: calc(var(--spacing) * 1.5);
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-2\.5 {
    gap: calc(var(--spacing) * 2.5);
  }
  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-5 {
    gap: calc(var(--spacing) * 5);
  }
  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }
  .gap-8 {
    gap: calc(var(--spacing) * 8);
  }
  .gap-12 {
    gap: calc(var(--spacing) * 12);
  }
  .space-y-0\.5 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 0.5) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 0.5) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-1 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-1\.5 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-2 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-3 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-4 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-5 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-6 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-8 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 8) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-20 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 20) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 20) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-x-1 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 1) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .space-x-1\.5 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 1.5) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .space-x-2 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .space-x-2\.5 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 2.5) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 2.5) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .space-x-3 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 3) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .space-x-5 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 5) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .gap-y-0\.5 {
    row-gap: calc(var(--spacing) * 0.5);
  }
  .divide-y {
    :where(& > :not(:last-child)) {
      --tw-divide-y-reverse: 0;
      border-bottom-style: var(--tw-border-style);
      border-top-style: var(--tw-border-style);
      border-top-width: calc(1px * var(--tw-divide-y-reverse));
      border-bottom-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
    }
  }
  .divide-gray-50 {
    :where(& > :not(:last-child)) {
      border-color: var(--color-gray-50);
    }
  }
  .divide-gray-100 {
    :where(& > :not(:last-child)) {
      border-color: var(--color-gray-100);
    }
  }
  .divide-gray-200 {
    :where(& > :not(:last-child)) {
      border-color: var(--color-gray-200);
    }
  }
  .divide-manifest-border {
    :where(& > :not(:last-child)) {
      border-color: var(--color-manifest-border);
    }
  }
  .self-start {
    align-self: flex-start;
  }
  .truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .overflow-x-auto {
    overflow-x: auto;
  }
  .overflow-x-hidden {
    overflow-x: hidden;
  }
  .overflow-y-auto {
    overflow-y: auto;
  }
  .overscroll-contain {
    overscroll-behavior: contain;
  }
  .scroll-smooth {
    scroll-behavior: smooth;
  }
  .tabs-box {
    background-color: var(--color-base-200);
    padding: calc(0.25rem * 1);
    border-radius: calc( var(--radius-field) + min(0.25rem, calc(var(--radius-field) + var(--radius-field) + var(--radius-field))) );
    box-shadow: 0 -0.5px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 0.5px oklch(0% 0 0 / calc(var(--depth) * 0.05)) inset;
    .tab {
      border-radius: var(--radius-field);
      border-style: none;
      &:focus-visible, &:is(label:has(:checked:focus-visible)) {
        outline-offset: 2px;
      }
    }
    :is(.tab-active, [aria-selected="true"]):not(.tab-disabled, [disabled]), :is(input:checked), :is(label:has(:checked)) {
      background-color: var(--tab-bg, var(--color-base-100));
      box-shadow: 0 1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px 1px -1px var(--color-neutral), 0 1px 6px -4px var(--color-neutral);
      @supports (color: color-mix(in lab, red, red)) {
        box-shadow: 0 1px oklch(100% 0 0 / calc(var(--depth) * 0.1)) inset, 0 1px 1px -1px color-mix(in oklab, var(--color-neutral) calc(var(--depth) * 50%), #0000), 0 1px 6px -4px color-mix(in oklab, var(--color-neutral) calc(var(--depth) * 100%), #0000);
      }
      @media (forced-colors: active) {
        border: 1px solid;
      }
    }
  }
  .timeline-box {
    border: var(--border) solid;
    border-radius: var(--radius-box);
    border-color: var(--color-base-300);
    background-color: var(--color-base-100);
    padding-inline: calc(0.25rem * 4);
    padding-block: calc(0.25rem * 2);
    font-size: 0.75rem;
    box-shadow: 0 1px 2px 0 oklch(0% 0 0/0.05);
  }
  .menu-lg {
    :where(li:not(.menu-title) > *:not(ul, details, .menu-title)), :where(li:not(.menu-title) > details > summary:not(.menu-title)) {
      border-radius: var(--radius-field);
      padding-inline: calc(0.25rem * 4);
      padding-block: calc(0.25rem * 1.5);
      font-size: 1.125rem;
    }
    .menu-title {
      padding-inline: calc(0.25rem * 6);
      padding-block: calc(0.25rem * 3);
    }
  }
  .menu-md {
    :where(li:not(.menu-title) > *:not(ul, details, .menu-title)), :where(li:not(.menu-title) > details > summary:not(.menu-title)) {
      border-radius: var(--radius-field);
      padding-inline: calc(0.25rem * 3);
      padding-block: calc(0.25rem * 1.5);
      font-size: 0.875rem;
    }
    .menu-title {
      padding-inline: calc(0.25rem * 3);
      padding-block: calc(0.25rem * 2);
    }
  }
  .menu-sm {
    :where(li:not(.menu-title) > *:not(ul, details, .menu-title)), :where(li:not(.menu-title) > details > summary:not(.menu-title)) {
      border-radius: var(--radius-field);
      padding-inline: calc(0.25rem * 2.5);
      padding-block: calc(0.25rem * 1);
      font-size: 0.75rem;
    }
    .menu-title {
      padding-inline: calc(0.25rem * 3);
      padding-block: calc(0.25rem * 2);
    }
  }
  .menu-xl {
    :where(li:not(.menu-title) > *:not(ul, details, .menu-title)), :where(li:not(.menu-title) > details > summary:not(.menu-title)) {
      border-radius: var(--radius-field);
      padding-inline: calc(0.25rem * 5);
      padding-block: calc(0.25rem * 1.5);
      font-size: 1.375rem;
    }
    .menu-title {
      padding-inline: calc(0.25rem * 6);
      padding-block: calc(0.25rem * 3);
    }
  }
  .menu-xs {
    :where(li:not(.menu-title) > *:not(ul, details, .menu-title)), :where(li:not(.menu-title) > details > summary:not(.menu-title)) {
      border-radius: var(--radius-field);
      padding-inline: calc(0.25rem * 2);
      padding-block: calc(0.25rem * 1);
      font-size: 0.6875rem;
    }
    .menu-title {
      padding-inline: calc(0.25rem * 2);
      padding-block: calc(0.25rem * 1);
    }
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .rounded-2xl {
    border-radius: var(--radius-2xl);
  }
  .rounded-3xl {
    border-radius: var(--radius-3xl);
  }
  .rounded-\[10px\] {
    border-radius: 10px;
  }
  .rounded-\[18px\] {
    border-radius: 18px;
  }
  .rounded-\[20px\] {
    border-radius: 20px;
  }
  .rounded-box {
    border-radius: var(--radius-box);
  }
  .rounded-box {
    border-radius: var(--radius-box);
  }
  .rounded-field {
    border-radius: var(--radius-field);
  }
  .rounded-field {
    border-radius: var(--radius-field);
  }
  .rounded-full {
    border-radius: calc(infinity * 1px);
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .rounded-md {
    border-radius: var(--radius-md);
  }
  .rounded-none {
    border-radius: 0;
  }
  .rounded-selector {
    border-radius: var(--radius-selector);
  }
  .rounded-selector {
    border-radius: var(--radius-selector);
  }
  .rounded-sm {
    border-radius: var(--radius-sm);
  }
  .rounded-xl {
    border-radius: var(--radius-xl);
  }
  .rounded-t-2xl {
    border-top-left-radius: var(--radius-2xl);
    border-top-right-radius: var(--radius-2xl);
  }
  .rounded-t-3xl {
    border-top-left-radius: var(--radius-3xl);
    border-top-right-radius: var(--radius-3xl);
  }
  .rounded-t-box {
    border-top-left-radius: var(--radius-box);
    border-top-right-radius: var(--radius-box);
  }
  .rounded-t-box {
    border-top-left-radius: var(--radius-box);
    border-top-right-radius: var(--radius-box);
  }
  .rounded-t-field {
    border-top-left-radius: var(--radius-field);
    border-top-right-radius: var(--radius-field);
  }
  .rounded-t-field {
    border-top-left-radius: var(--radius-field);
    border-top-right-radius: var(--radius-field);
  }
  .rounded-t-selector {
    border-top-left-radius: var(--radius-selector);
    border-top-right-radius: var(--radius-selector);
  }
  .rounded-t-selector {
    border-top-left-radius: var(--radius-selector);
    border-top-right-radius: var(--radius-selector);
  }
  .rounded-l-box {
    border-top-left-radius: var(--radius-box);
    border-bottom-left-radius: var(--radius-box);
  }
  .rounded-l-box {
    border-top-left-radius: var(--radius-box);
    border-bottom-left-radius: var(--radius-box);
  }
  .rounded-l-field {
    border-top-left-radius: var(--radius-field);
    border-bottom-left-radius: var(--radius-field);
  }
  .rounded-l-field {
    border-top-left-radius: var(--radius-field);
    border-bottom-left-radius: var(--radius-field);
  }
  .rounded-l-selector {
    border-top-left-radius: var(--radius-selector);
    border-bottom-left-radius: var(--radius-selector);
  }
  .rounded-l-selector {
    border-top-left-radius: var(--radius-selector);
    border-bottom-left-radius: var(--radius-selector);
  }
  .rounded-tl-box {
    border-top-left-radius: var(--radius-box);
  }
  .rounded-tl-box {
    border-top-left-radius: var(--radius-box);
  }
  .rounded-tl-field {
    border-top-left-radius: var(--radius-field);
  }
  .rounded-tl-field {
    border-top-left-radius: var(--radius-field);
  }
  .rounded-tl-md {
    border-top-left-radius: var(--radius-md);
  }
  .rounded-tl-selector {
    border-top-left-radius: var(--radius-selector);
  }
  .rounded-tl-selector {
    border-top-left-radius: var(--radius-selector);
  }
  .rounded-r-box {
    border-top-right-radius: var(--radius-box);
    border-bottom-right-radius: var(--radius-box);
  }
  .rounded-r-box {
    border-top-right-radius: var(--radius-box);
    border-bottom-right-radius: var(--radius-box);
  }
  .rounded-r-field {
    border-top-right-radius: var(--radius-field);
    border-bottom-right-radius: var(--radius-field);
  }
  .rounded-r-field {
    border-top-right-radius: var(--radius-field);
    border-bottom-right-radius: var(--radius-field);
  }
  .rounded-r-selector {
    border-top-right-radius: var(--radius-selector);
    border-bottom-right-radius: var(--radius-selector);
  }
  .rounded-r-selector {
    border-top-right-radius: var(--radius-selector);
    border-bottom-right-radius: var(--radius-selector);
  }
  .rounded-tr-box {
    border-top-right-radius: var(--radius-box);
  }
  .rounded-tr-box {
    border-top-right-radius: var(--radius-box);
  }
  .rounded-tr-field {
    border-top-right-radius: var(--radius-field);
  }
  .rounded-tr-field {
    border-top-right-radius: var(--radius-field);
  }
  .rounded-tr-md {
    border-top-right-radius: var(--radius-md);
  }
  .rounded-tr-selector {
    border-top-right-radius: var(--radius-selector);
  }
  .rounded-tr-selector {
    border-top-right-radius: var(--radius-selector);
  }
  .rounded-b-box {
    border-bottom-left-radius: var(--radius-box);
    border-bottom-right-radius: var(--radius-box);
  }
  .rounded-b-box {
    border-bottom-right-radius: var(--radius-box);
    border-bottom-left-radius: var(--radius-box);
  }
  .rounded-b-field {
    border-bottom-left-radius: var(--radius-field);
    border-bottom-right-radius: var(--radius-field);
  }
  .rounded-b-field {
    border-bottom-right-radius: var(--radius-field);
    border-bottom-left-radius: var(--radius-field);
  }
  .rounded-b-selector {
    border-bottom-left-radius: var(--radius-selector);
    border-bottom-right-radius: var(--radius-selector);
  }
  .rounded-b-selector {
    border-bottom-right-radius: var(--radius-selector);
    border-bottom-left-radius: var(--radius-selector);
  }
  .rounded-br-box {
    border-bottom-right-radius: var(--radius-box);
  }
  .rounded-br-box {
    border-bottom-right-radius: var(--radius-box);
  }
  .rounded-br-field {
    border-bottom-right-radius: var(--radius-field);
  }
  .rounded-br-field {
    border-bottom-right-radius: var(--radius-field);
  }
  .rounded-br-md {
    border-bottom-right-radius: var(--radius-md);
  }
  .rounded-br-selector {
    border-bottom-right-radius: var(--radius-selector);
  }
  .rounded-br-selector {
    border-bottom-right-radius: var(--radius-selector);
  }
  .rounded-bl-box {
    border-bottom-left-radius: var(--radius-box);
  }
  .rounded-bl-box {
    border-bottom-left-radius: var(--radius-box);
  }
  .rounded-bl-field {
    border-bottom-left-radius: var(--radius-field);
  }
  .rounded-bl-field {
    border-bottom-left-radius: var(--radius-field);
  }
  .rounded-bl-md {
    border-bottom-left-radius: var(--radius-md);
  }
  .rounded-bl-selector {
    border-bottom-left-radius: var(--radius-selector);
  }
  .rounded-bl-selector {
    border-bottom-left-radius: var(--radius-selector);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-1 {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-2 {
    border-style: var(--tw-border-style);
    border-width: 2px;
  }
  .border-\[3px\] {
    border-style: var(--tw-border-style);
    border-width: 3px;
  }
  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }
  .border-r {
    border-right-style: var(--tw-border-style);
    border-right-width: 1px;
  }
  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
  .border-b-0 {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 0px;
  }
  .btn-dash {
    &:not( .btn-active, :hover, :active:focus, :focus-visible, :disabled, [disabled], .btn-disabled, :checked ) {
      --btn-shadow: "";
      border-style: dashed;
      --btn-bg: #0000;
      --btn-fg: var(--btn-color);
      --btn-border: var(--btn-color);
      --btn-noise: none;
    }
  }
  .border-dashed {
    --tw-border-style: dashed;
    border-style: dashed;
  }
  .border-none {
    --tw-border-style: none;
    border-style: none;
  }
  .badge-ghost {
    border-color: var(--color-base-200);
    background-color: var(--color-base-200);
    color: var(--color-base-content);
    background-image: none;
  }
  .select-ghost {
    background-color: transparent;
    transition: background-color 0.2s;
    box-shadow: none;
    border-color: #0000;
    &:focus, &:focus-within {
      background-color: var(--color-base-100);
      color: var(--color-base-content);
      border-color: #0000;
      box-shadow: none;
    }
  }
  .input-ghost {
    background-color: transparent;
    box-shadow: none;
    border-color: #0000;
    &:focus, &:focus-within {
      background-color: var(--color-base-100);
      color: var(--color-base-content);
      border-color: #0000;
      box-shadow: none;
    }
  }
  .textarea-ghost {
    background-color: transparent;
    box-shadow: none;
    border-color: #0000;
    &:focus, &:focus-within {
      background-color: var(--color-base-100);
      color: var(--color-base-content);
      border-color: #0000;
      box-shadow: none;
    }
  }
  .alert-error {
    border-color: var(--color-error);
    color: var(--color-error-content);
    --alert-color: var(--color-error);
  }
  .alert-info {
    border-color: var(--color-info);
    color: var(--color-info-content);
    --alert-color: var(--color-info);
  }
  .alert-success {
    border-color: var(--color-success);
    color: var(--color-success-content);
    --alert-color: var(--color-success);
  }
  .alert-warning {
    border-color: var(--color-warning);
    color: var(--color-warning-content);
    --alert-color: var(--color-warning);
  }
  .border-amber-100 {
    border-color: var(--color-amber-100);
  }
  .border-amber-200 {
    border-color: var(--color-amber-200);
  }
  .border-amber-300 {
    border-color: var(--color-amber-300);
  }
  .border-base-200 {
    border-color: var(--color-base-200);
  }
  .border-base-300 {
    border-color: var(--color-base-300);
  }
  .border-blue-200 {
    border-color: var(--color-blue-200);
  }
  .border-emerald-100 {
    border-color: var(--color-emerald-100);
  }
  .border-emerald-200 {
    border-color: var(--color-emerald-200);
  }
  .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-green-200 {
    border-color: var(--color-green-200);
  }
  .border-green-400 {
    border-color: var(--color-green-400);
  }
  .border-green-500 {
    border-color: var(--color-green-500);
  }
  .border-indigo-100 {
    border-color: var(--color-indigo-100);
  }
  .border-indigo-200 {
    border-color: var(--color-indigo-200);
  }
  .border-indigo-300 {
    border-color: var(--color-indigo-300);
  }
  .border-indigo-400 {
    border-color: var(--color-indigo-400);
  }
  .border-indigo-500 {
    border-color: var(--color-indigo-500);
  }
  .border-indigo-600 {
    border-color: var(--color-indigo-600);
  }
  .border-manifest-bg-muted {
    border-color: var(--color-manifest-bg-muted);
  }
  .border-manifest-border {
    border-color: var(--color-manifest-border);
  }
  .border-manifest-card {
    border-color: var(--color-manifest-card);
  }
  .border-manifest-danger {
    border-color: var(--color-manifest-danger);
  }
  .border-manifest-danger-border {
    border-color: var(--color-manifest-danger-border);
  }
  .border-manifest-info-light {
    border-color: var(--color-manifest-info-light);
  }
  .border-manifest-primary {
    border-color: var(--color-manifest-primary);
  }
  .border-manifest-primary-border {
    border-color: var(--color-manifest-primary-border);
  }
  .border-manifest-success-light {
    border-color: var(--color-manifest-success-light);
  }
  .border-neutral-100 {
    border-color: var(--color-neutral-100);
  }
  .border-orange-200 {
    border-color: var(--color-orange-200);
  }
  .border-orange-300 {
    border-color: var(--color-orange-300);
  }
  .border-pink-100 {
    border-color: var(--color-pink-100);
  }
  .border-pink-200 {
    border-color: var(--color-pink-200);
  }
  .border-purple-100 {
    border-color: var(--color-purple-100);
  }
  .border-red-100 {
    border-color: var(--color-red-100);
  }
  .border-red-200 {
    border-color: var(--color-red-200);
  }
  .border-red-400 {
    border-color: var(--color-red-400);
  }
  .border-red-500 {
    border-color: var(--color-red-500);
  }
  .border-slate-200 {
    border-color: var(--color-slate-200);
  }
  .border-teal-100 {
    border-color: var(--color-teal-100);
  }
  .border-teal-200 {
    border-color: var(--color-teal-200);
  }
  .border-transparent {
    border-color: transparent;
  }
  .border-white {
    border-color: var(--color-white);
  }
  .border-yellow-200 {
    border-color: var(--color-yellow-200);
  }
  .border-t-transparent {
    border-top-color: transparent;
  }
  .glass {
    border: none;
    backdrop-filter: blur(var(--glass-blur, 40px));
    background-color: #0000;
    background-image: linear-gradient( 135deg, oklch(100% 0 0 / var(--glass-opacity, 30%)) 0%, oklch(0% 0 0 / 0%) 100% ), linear-gradient( var(--glass-reflect-degree, 100deg), oklch(100% 0 0 / var(--glass-reflect-opacity, 5%)) 25%, oklch(0% 0 0 / 0%) 25% );
    box-shadow: 0 0 0 1px oklch(100% 0 0 / var(--glass-border-opacity, 20%)) inset, 0 0 0 2px oklch(0% 0 0 / 5%);
    text-shadow: 0 1px oklch(0% 0 0 / var(--glass-text-shadow-opacity, 5%));
  }
  .chat-bubble-accent {
    background-color: var(--color-accent);
    color: var(--color-accent-content);
  }
  .chat-bubble-error {
    background-color: var(--color-error);
    color: var(--color-error-content);
  }
  .chat-bubble-info {
    background-color: var(--color-info);
    color: var(--color-info-content);
  }
  .chat-bubble-neutral {
    background-color: var(--color-neutral);
    color: var(--color-neutral-content);
  }
  .chat-bubble-primary {
    background-color: var(--color-primary);
    color: var(--color-primary-content);
  }
  .chat-bubble-secondary {
    background-color: var(--color-secondary);
    color: var(--color-secondary-content);
  }
  .chat-bubble-success {
    background-color: var(--color-success);
    color: var(--color-success-content);
  }
  .chat-bubble-warning {
    background-color: var(--color-warning);
    color: var(--color-warning-content);
  }
  .status-accent {
    background-color: var(--color-accent);
    color: var(--color-accent);
  }
  .status-error {
    background-color: var(--color-error);
    color: var(--color-error);
  }
  .status-info {
    background-color: var(--color-info);
    color: var(--color-info);
  }
  .status-neutral {
    background-color: var(--color-neutral);
    color: var(--color-neutral);
  }
  .status-primary {
    background-color: var(--color-primary);
    color: var(--color-primary);
  }
  .status-secondary {
    background-color: var(--color-secondary);
    color: var(--color-secondary);
  }
  .status-success {
    background-color: var(--color-success);
    color: var(--color-success);
  }
  .status-warning {
    background-color: var(--color-warning);
    color: var(--color-warning);
  }
  .table-zebra {
    tbody {
      tr {
        &:nth-child(even) {
          background-color: var(--color-base-200);
          :where(.table-pin-cols tr th) {
            background-color: var(--color-base-200);
          }
        }
        &.row-hover {
          &, &:nth-child(even) {
            &:hover {
              @media (hover: hover) {
                background-color: var(--color-base-300);
              }
            }
          }
        }
      }
    }
  }
  .bg-\[\#0A66C2\] {
    background-color: #0A66C2;
  }
  .bg-amber-50 {
    background-color: var(--color-amber-50);
  }
  .bg-amber-100 {
    background-color: var(--color-amber-100);
  }
  .bg-amber-200 {
    background-color: var(--color-amber-200);
  }
  .bg-amber-400 {
    background-color: var(--color-amber-400);
  }
  .bg-amber-500 {
    background-color: var(--color-amber-500);
  }
  .bg-base-100 {
    background-color: var(--color-base-100);
  }
  .bg-base-200 {
    background-color: var(--color-base-200);
  }
  .bg-base-300 {
    background-color: var(--color-base-300);
  }
  .bg-black {
    background-color: var(--color-black);
  }
  .bg-black\/20 {
    background-color: color-mix(in srgb, #000 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 20%, transparent);
    }
  }
  .bg-black\/30 {
    background-color: color-mix(in srgb, #000 30%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 30%, transparent);
    }
  }
  .bg-black\/40 {
    background-color: color-mix(in srgb, #000 40%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 40%, transparent);
    }
  }
  .bg-black\/50 {
    background-color: color-mix(in srgb, #000 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 50%, transparent);
    }
  }
  .bg-black\/60 {
    background-color: color-mix(in srgb, #000 60%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 60%, transparent);
    }
  }
  .bg-blue-50 {
    background-color: var(--color-blue-50);
  }
  .bg-blue-100 {
    background-color: var(--color-blue-100);
  }
  .bg-blue-500 {
    background-color: var(--color-blue-500);
  }
  .bg-cyan-100 {
    background-color: var(--color-cyan-100);
  }
  .bg-emerald-50 {
    background-color: var(--color-emerald-50);
  }
  .bg-emerald-100 {
    background-color: var(--color-emerald-100);
  }
  .bg-emerald-600 {
    background-color: var(--color-emerald-600);
  }
  .bg-gray-50 {
    background-color: var(--color-gray-50);
  }
  .bg-gray-100 {
    background-color: var(--color-gray-100);
  }
  .bg-gray-300 {
    background-color: var(--color-gray-300);
  }
  .bg-green-50 {
    background-color: var(--color-green-50);
  }
  .bg-green-100 {
    background-color: var(--color-green-100);
  }
  .bg-green-400 {
    background-color: var(--color-green-400);
  }
  .bg-green-500 {
    background-color: var(--color-green-500);
  }
  .bg-green-600 {
    background-color: var(--color-green-600);
  }
  .bg-indigo-50 {
    background-color: var(--color-indigo-50);
  }
  .bg-indigo-50\/70 {
    background-color: color-mix(in srgb, oklch(96.2% 0.018 272.314) 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-indigo-50) 70%, transparent);
    }
  }
  .bg-indigo-100 {
    background-color: var(--color-indigo-100);
  }
  .bg-indigo-200 {
    background-color: var(--color-indigo-200);
  }
  .bg-indigo-400 {
    background-color: var(--color-indigo-400);
  }
  .bg-indigo-600 {
    background-color: var(--color-indigo-600);
  }
  .bg-lime-100 {
    background-color: var(--color-lime-100);
  }
  .bg-manifest-bg {
    background-color: var(--color-manifest-bg);
  }
  .bg-manifest-bg-muted {
    background-color: var(--color-manifest-bg-muted);
  }
  .bg-manifest-bg\/50 {
    background-color: color-mix(in srgb, #FDFCFB 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-manifest-bg) 50%, transparent);
    }
  }
  .bg-manifest-bg\/80 {
    background-color: color-mix(in srgb, #FDFCFB 80%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-manifest-bg) 80%, transparent);
    }
  }
  .bg-manifest-border {
    background-color: var(--color-manifest-border);
  }
  .bg-manifest-border\/60 {
    background-color: color-mix(in srgb, #E8E4E0 60%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-manifest-border) 60%, transparent);
    }
  }
  .bg-manifest-card {
    background-color: var(--color-manifest-card);
  }
  .bg-manifest-card\/70 {
    background-color: color-mix(in srgb, #FFFFFF 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-manifest-card) 70%, transparent);
    }
  }
  .bg-manifest-card\/90 {
    background-color: color-mix(in srgb, #FFFFFF 90%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-manifest-card) 90%, transparent);
    }
  }
  .bg-manifest-card\/95 {
    background-color: color-mix(in srgb, #FFFFFF 95%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-manifest-card) 95%, transparent);
    }
  }
  .bg-manifest-cat-dark {
    background-color: var(--color-manifest-cat-dark);
  }
  .bg-manifest-danger {
    background-color: var(--color-manifest-danger);
  }
  .bg-manifest-danger-light {
    background-color: var(--color-manifest-danger-light);
  }
  .bg-manifest-danger-lighter {
    background-color: var(--color-manifest-danger-lighter);
  }
  .bg-manifest-info {
    background-color: var(--color-manifest-info);
  }
  .bg-manifest-info-light {
    background-color: var(--color-manifest-info-light);
  }
  .bg-manifest-primary {
    background-color: var(--color-manifest-primary);
  }
  .bg-manifest-primary-dark {
    background-color: var(--color-manifest-primary-dark);
  }
  .bg-manifest-primary-light {
    background-color: var(--color-manifest-primary-light);
  }
  .bg-manifest-secondary {
    background-color: var(--color-manifest-secondary);
  }
  .bg-manifest-secondary-light {
    background-color: var(--color-manifest-secondary-light);
  }
  .bg-manifest-success {
    background-color: var(--color-manifest-success);
  }
  .bg-manifest-success-light {
    background-color: var(--color-manifest-success-light);
  }
  .bg-manifest-text {
    background-color: var(--color-manifest-text);
  }
  .bg-manifest-text-muted {
    background-color: var(--color-manifest-text-muted);
  }
  .bg-manifest-warning {
    background-color: var(--color-manifest-warning);
  }
  .bg-manifest-warning-light {
    background-color: var(--color-manifest-warning-light);
  }
  .bg-neutral {
    background-color: var(--color-neutral);
  }
  .bg-neutral-50 {
    background-color: var(--color-neutral-50);
  }
  .bg-orange-50 {
    background-color: var(--color-orange-50);
  }
  .bg-orange-100 {
    background-color: var(--color-orange-100);
  }
  .bg-orange-500 {
    background-color: var(--color-orange-500);
  }
  .bg-pink-100 {
    background-color: var(--color-pink-100);
  }
  .bg-pink-200 {
    background-color: var(--color-pink-200);
  }
  .bg-purple-50 {
    background-color: var(--color-purple-50);
  }
  .bg-purple-100 {
    background-color: var(--color-purple-100);
  }
  .bg-purple-200 {
    background-color: var(--color-purple-200);
  }
  .bg-purple-400 {
    background-color: var(--color-purple-400);
  }
  .bg-red-50 {
    background-color: var(--color-red-50);
  }
  .bg-red-100 {
    background-color: var(--color-red-100);
  }
  .bg-red-500 {
    background-color: var(--color-red-500);
  }
  .bg-rose-100 {
    background-color: var(--color-rose-100);
  }
  .bg-sky-100 {
    background-color: var(--color-sky-100);
  }
  .bg-teal-50 {
    background-color: var(--color-teal-50);
  }
  .bg-teal-50\/70 {
    background-color: color-mix(in srgb, oklch(98.4% 0.014 180.72) 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-teal-50) 70%, transparent);
    }
  }
  .bg-teal-100 {
    background-color: var(--color-teal-100);
  }
  .bg-transparent {
    background-color: transparent;
  }
  .bg-violet-50 {
    background-color: var(--color-violet-50);
  }
  .bg-violet-100 {
    background-color: var(--color-violet-100);
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .bg-white\/10 {
    background-color: color-mix(in srgb, #fff 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }
  .bg-white\/20 {
    background-color: color-mix(in srgb, #fff 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 20%, transparent);
    }
  }
  .bg-white\/30 {
    background-color: color-mix(in srgb, #fff 30%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 30%, transparent);
    }
  }
  .bg-white\/95 {
    background-color: color-mix(in srgb, #fff 95%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 95%, transparent);
    }
  }
  .bg-yellow-50 {
    background-color: var(--color-yellow-50);
  }
  .bg-yellow-100 {
    background-color: var(--color-yellow-100);
  }
  .divider-accent {
    &:before, &:after {
      background-color: var(--color-accent);
    }
  }
  .divider-error {
    &:before, &:after {
      background-color: var(--color-error);
    }
  }
  .divider-info {
    &:before, &:after {
      background-color: var(--color-info);
    }
  }
  .divider-neutral {
    &:before, &:after {
      background-color: var(--color-neutral);
    }
  }
  .divider-primary {
    &:before, &:after {
      background-color: var(--color-primary);
    }
  }
  .divider-secondary {
    &:before, &:after {
      background-color: var(--color-secondary);
    }
  }
  .divider-success {
    &:before, &:after {
      background-color: var(--color-success);
    }
  }
  .divider-warning {
    &:before, &:after {
      background-color: var(--color-warning);
    }
  }
  .bg-gradient-to-br {
    --tw-gradient-position: to bottom right in oklab;
    background-image: linear-gradient(var(--tw-gradient-stops));
  }
  .bg-gradient-to-r {
    --tw-gradient-position: to right in oklab;
    background-image: linear-gradient(var(--tw-gradient-stops));
  }
  .from-amber-50 {
    --tw-gradient-from: var(--color-amber-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-emerald-50 {
    --tw-gradient-from: var(--color-emerald-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-green-50 {
    --tw-gradient-from: var(--color-green-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-green-400 {
    --tw-gradient-from: var(--color-green-400);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-indigo-50 {
    --tw-gradient-from: var(--color-indigo-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-indigo-100 {
    --tw-gradient-from: var(--color-indigo-100);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-indigo-500 {
    --tw-gradient-from: var(--color-indigo-500);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-indigo-600 {
    --tw-gradient-from: var(--color-indigo-600);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-manifest-accent {
    --tw-gradient-from: var(--color-manifest-accent);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-manifest-info {
    --tw-gradient-from: var(--color-manifest-info);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-manifest-primary {
    --tw-gradient-from: var(--color-manifest-primary);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-manifest-primary-light {
    --tw-gradient-from: var(--color-manifest-primary-light);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-manifest-primary-light\/60 {
    --tw-gradient-from: color-mix(in srgb, #EEF2FF 60%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-gradient-from: color-mix(in oklab, var(--color-manifest-primary-light) 60%, transparent);
    }
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-manifest-secondary {
    --tw-gradient-from: var(--color-manifest-secondary);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-manifest-secondary-light {
    --tw-gradient-from: var(--color-manifest-secondary-light);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-manifest-success {
    --tw-gradient-from: var(--color-manifest-success);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-pink-100 {
    --tw-gradient-from: var(--color-pink-100);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-red-50 {
    --tw-gradient-from: var(--color-red-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-slate-50 {
    --tw-gradient-from: var(--color-slate-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .from-teal-50 {
    --tw-gradient-from: var(--color-teal-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .via-emerald-500 {
    --tw-gradient-via: var(--color-emerald-500);
    --tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-via-stops);
  }
  .via-purple-600 {
    --tw-gradient-via: var(--color-purple-600);
    --tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-via-stops);
  }
  .to-blue-100 {
    --tw-gradient-to: var(--color-blue-100);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-cyan-50 {
    --tw-gradient-to: var(--color-cyan-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-emerald-50 {
    --tw-gradient-to: var(--color-emerald-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-indigo-50 {
    --tw-gradient-to: var(--color-indigo-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-indigo-200 {
    --tw-gradient-to: var(--color-indigo-200);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-manifest-accent {
    --tw-gradient-to: var(--color-manifest-accent);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-manifest-accent-light {
    --tw-gradient-to: var(--color-manifest-accent-light);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-manifest-bg {
    --tw-gradient-to: var(--color-manifest-bg);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-manifest-card {
    --tw-gradient-to: var(--color-manifest-card);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-manifest-danger {
    --tw-gradient-to: var(--color-manifest-danger);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-manifest-info {
    --tw-gradient-to: var(--color-manifest-info);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-manifest-primary {
    --tw-gradient-to: var(--color-manifest-primary);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-manifest-primary-light {
    --tw-gradient-to: var(--color-manifest-primary-light);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-manifest-secondary {
    --tw-gradient-to: var(--color-manifest-secondary);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-orange-50 {
    --tw-gradient-to: var(--color-orange-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-orange-100 {
    --tw-gradient-to: var(--color-orange-100);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-pink-200 {
    --tw-gradient-to: var(--color-pink-200);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-purple-50 {
    --tw-gradient-to: var(--color-purple-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-purple-100 {
    --tw-gradient-to: var(--color-purple-100);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-purple-500 {
    --tw-gradient-to: var(--color-purple-500);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-purple-600 {
    --tw-gradient-to: var(--color-purple-600);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-teal-50 {
    --tw-gradient-to: var(--color-teal-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-teal-500 {
    --tw-gradient-to: var(--color-teal-500);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-violet-50 {
    --tw-gradient-to: var(--color-violet-50);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-violet-600 {
    --tw-gradient-to: var(--color-violet-600);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-white {
    --tw-gradient-to: var(--color-white);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .loading-ball {
    mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cellipse cx='12' cy='5' rx='4' ry='4'%3E%3Canimate attributeName='cy' values='5;20;20.5;20;5' keyTimes='0;0.469;0.5;0.531;1' dur='.8s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1'/%3E%3Canimate attributeName='rx' values='4;4;4.8;4;4' keyTimes='0;0.469;0.5;0.531;1' dur='.8s' repeatCount='indefinite'/%3E%3Canimate attributeName='ry' values='4;4;3;4;4' keyTimes='0;0.469;0.5;0.531;1' dur='.8s' repeatCount='indefinite'/%3E%3C/ellipse%3E%3C/svg%3E");
  }
  .loading-bars {
    mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='1' y='1' width='6' height='22'%3E%3Canimate attributeName='y' values='1;5;1' keyTimes='0;0.938;1' dur='.8s' repeatCount='indefinite'/%3E%3Canimate attributeName='height' values='22;14;22' keyTimes='0;0.938;1' dur='.8s' repeatCount='indefinite'/%3E%3Canimate attributeName='opacity' values='1;0.2;1' keyTimes='0;0.938;1' dur='.8s' repeatCount='indefinite'/%3E%3C/rect%3E%3Crect x='9' y='1' width='6' height='22'%3E%3Canimate attributeName='y' values='1;5;1' keyTimes='0;0.938;1' dur='.8s' repeatCount='indefinite' begin='-0.65s'/%3E%3Canimate attributeName='height' values='22;14;22' keyTimes='0;0.938;1' dur='.8s' repeatCount='indefinite' begin='-0.65s'/%3E%3Canimate attributeName='opacity' values='1;0.2;1' keyTimes='0;0.938;1' dur='.8s' repeatCount='indefinite' begin='-0.65s'/%3E%3C/rect%3E%3Crect x='17' y='1' width='6' height='22'%3E%3Canimate attributeName='y' values='1;5;1' keyTimes='0;0.938;1' dur='.8s' repeatCount='indefinite' begin='-0.5s'/%3E%3Canimate attributeName='height' values='22;14;22' keyTimes='0;0.938;1' dur='.8s' repeatCount='indefinite' begin='-0.5s'/%3E%3Canimate attributeName='opacity' values='1;0.2;1' keyTimes='0;0.938;1' dur='.8s' repeatCount='indefinite' begin='-0.5s'/%3E%3C/rect%3E%3C/svg%3E");
  }
  .loading-dots {
    mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='4' cy='12' r='3'%3E%3Canimate attributeName='cy' values='12;6;12;12' keyTimes='0;0.286;0.571;1' dur='1.05s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1'/%3E%3C/circle%3E%3Ccircle cx='12' cy='12' r='3'%3E%3Canimate attributeName='cy' values='12;6;12;12' keyTimes='0;0.286;0.571;1' dur='1.05s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1' begin='0.1s'/%3E%3C/circle%3E%3Ccircle cx='20' cy='12' r='3'%3E%3Canimate attributeName='cy' values='12;6;12;12' keyTimes='0;0.286;0.571;1' dur='1.05s' repeatCount='indefinite' keySplines='.33,0,.66,.33;.33,.66,.66,1' begin='0.2s'/%3E%3C/circle%3E%3C/svg%3E");
  }
  .loading-infinity {
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' style='shape-rendering:auto;' width='200px' height='200px' viewBox='0 0 100 100' preserveAspectRatio='xMidYMid'%3E%3Cpath fill='none' stroke='black' stroke-width='10' stroke-dasharray='205.271 51.318' d='M24.3 30C11.4 30 5 43.3 5 50s6.4 20 19.3 20c19.3 0 32.1-40 51.4-40C88.6 30 95 43.3 95 50s-6.4 20-19.3 20C56.4 70 43.6 30 24.3 30z' stroke-linecap='round' style='transform:scale(0.8);transform-origin:50px 50px'%3E%3Canimate attributeName='stroke-dashoffset' repeatCount='indefinite' dur='2s' keyTimes='0;1' values='0;256.589'/%3E%3C/path%3E%3C/svg%3E");
  }
  .loading-ring {
    mask-image: url("data:image/svg+xml,%3Csvg width='44' height='44' viewBox='0 0 44 44' xmlns='http://www.w3.org/2000/svg' stroke='white'%3E%3Cg fill='none' fill-rule='evenodd' stroke-width='2'%3E%3Ccircle cx='22' cy='22' r='1'%3E%3Canimate attributeName='r' begin='0s' dur='1.8s' values='1;20' calcMode='spline' keyTimes='0;1' keySplines='0.165,0.84,0.44,1' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-opacity' begin='0s' dur='1.8s' values='1;0' calcMode='spline' keyTimes='0;1' keySplines='0.3,0.61,0.355,1' repeatCount='indefinite'/%3E%3C/circle%3E%3Ccircle cx='22' cy='22' r='1'%3E%3Canimate attributeName='r' begin='-0.9s' dur='1.8s' values='1;20' calcMode='spline' keyTimes='0;1' keySplines='0.165,0.84,0.44,1' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-opacity' begin='-0.9s' dur='1.8s' values='1;0' calcMode='spline' keyTimes='0;1' keySplines='0.3,0.61,0.355,1' repeatCount='indefinite'/%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");
  }
  .loading-spinner {
    mask-image: url("data:image/svg+xml,%3Csvg width='24' height='24' stroke='black' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cg transform-origin='center'%3E%3Ccircle cx='12' cy='12' r='9.5' fill='none' stroke-width='3' stroke-linecap='round'%3E%3CanimateTransform attributeName='transform' type='rotate' from='0 12 12' to='360 12 12' dur='2s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dasharray' values='0,150;42,150;42,150' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3Canimate attributeName='stroke-dashoffset' values='0;-16;-59' keyTimes='0;0.475;1' dur='1.5s' repeatCount='indefinite'/%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");
  }
  .mask-circle {
    mask-image: url("data:image/svg+xml,%3csvg width='200' height='200' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle fill='black' cx='100' cy='100' r='100' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-decagon {
    mask-image: url("data:image/svg+xml,%3csvg width='192' height='200' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='m96 0 58.779 19.098 36.327 50v61.804l-36.327 50L96 200l-58.779-19.098-36.327-50V69.098l36.327-50z' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-diamond {
    mask-image: url("data:image/svg+xml,%3csvg width='200' height='200' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='m100 0 100 100-100 100L0 100z' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-heart {
    mask-image: url("data:image/svg+xml,%3csvg width='200' height='185' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M100 184.606a15.384 15.384 0 0 1-8.653-2.678C53.565 156.28 37.205 138.695 28.182 127.7 8.952 104.264-.254 80.202.005 54.146.308 24.287 24.264 0 53.406 0c21.192 0 35.869 11.937 44.416 21.879a2.884 2.884 0 0 0 4.356 0C110.725 11.927 125.402 0 146.594 0c29.142 0 53.098 24.287 53.4 54.151.26 26.061-8.956 50.122-28.176 73.554-9.023 10.994-25.383 28.58-63.165 54.228a15.384 15.384 0 0 1-8.653 2.673Z' fill='black' fill-rule='nonzero'/%3e%3c/svg%3e");
  }
  .mask-hexagon {
    mask-image: url("data:image/svg+xml,%3csvg width='182' height='201' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M.3 65.486c0-9.196 6.687-20.063 14.211-25.078l61.86-35.946c8.36-5.016 20.899-5.016 29.258 0l61.86 35.946c8.36 5.015 14.211 15.882 14.211 25.078v71.055c0 9.196-6.687 20.063-14.211 25.079l-61.86 35.945c-8.36 4.18-20.899 4.18-29.258 0L14.51 161.62C6.151 157.44.3 145.737.3 136.54V65.486Z' fill='black' fill-rule='nonzero'/%3e%3c/svg%3e");
  }
  .mask-hexagon-2 {
    mask-image: url("data:image/svg+xml,%3csvg width='200' height='182' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M64.786 181.4c-9.196 0-20.063-6.687-25.079-14.21L3.762 105.33c-5.016-8.36-5.016-20.9 0-29.259l35.945-61.86C44.723 5.851 55.59 0 64.786 0h71.055c9.196 0 20.063 6.688 25.079 14.211l35.945 61.86c4.18 8.36 4.18 20.899 0 29.258l-35.945 61.86c-4.18 8.36-15.883 14.211-25.079 14.211H64.786Z' fill='black' fill-rule='nonzero'/%3e%3c/svg%3e");
  }
  .mask-pentagon {
    mask-image: url("data:image/svg+xml,%3csvg width='192' height='181' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='m96 0 95.106 69.098-36.327 111.804H37.22L.894 69.098z' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-squircle {
    mask-image: url("data:image/svg+xml,%3csvg width='200' height='200' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M100 0C20 0 0 20 0 100s20 100 100 100 100-20 100-100S180 0 100 0Z'/%3e%3c/svg%3e");
  }
  .mask-star {
    mask-image: url("data:image/svg+xml,%3csvg width='192' height='180' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='m96 137.263-58.779 42.024 22.163-68.389L.894 68.481l72.476-.243L96 0l22.63 68.238 72.476.243-58.49 42.417 22.163 68.389z' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-star-2 {
    mask-image: url("data:image/svg+xml,%3csvg width='192' height='180' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='m96 153.044-58.779 26.243 7.02-63.513L.894 68.481l63.117-13.01L96 0l31.989 55.472 63.117 13.01-43.347 47.292 7.02 63.513z' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-triangle {
    mask-image: url("data:image/svg+xml,%3csvg width='174' height='149' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='m87 148.476-86.603.185L43.86 74.423 87 0l43.14 74.423 43.463 74.238z' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-triangle-2 {
    mask-image: url("data:image/svg+xml,%3csvg width='174' height='150' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='m87 .738 86.603-.184-43.463 74.238L87 149.214 43.86 74.792.397.554z' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-triangle-3 {
    mask-image: url("data:image/svg+xml,%3csvg width='150' height='174' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='m149.369 87.107.185 86.603-74.239-43.463L.893 87.107l74.422-43.14L149.554.505z' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-triangle-4 {
    mask-image: url("data:image/svg+xml,%3csvg width='150' height='174' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='M.631 87.107.446.505l74.239 43.462 74.422 43.14-74.422 43.14L.446 173.71z' fill-rule='evenodd'/%3e%3c/svg%3e");
  }
  .mask-circle {
    --tw-mask-radial-shape: circle;
  }
  .mask-half-1 {
    mask-size: 200%;
    mask-position: left;
    mask-position: left;
    &:where(:dir(rtl), [dir="rtl"], [dir="rtl"] *) {
      mask-position: right;
    }
  }
  .mask-half-2 {
    mask-size: 200%;
    mask-position: right;
    mask-position: right;
    &:where(:dir(rtl), [dir="rtl"], [dir="rtl"] *) {
      mask-position: left;
    }
  }
  .mask-repeat {
    mask-repeat: repeat;
  }
  .stroke-manifest-danger {
    stroke: var(--color-manifest-danger);
  }
  .stroke-manifest-primary {
    stroke: var(--color-manifest-primary);
  }
  .stroke-manifest-text-muted {
    stroke: var(--color-manifest-text-muted);
  }
  .stroke-white {
    stroke: var(--color-white);
  }
  .object-cover {
    object-fit: cover;
  }
  .checkbox-lg {
    padding: 0.3125rem;
    --size: calc(var(--size-selector, 0.25rem) * 7);
  }
  .checkbox-md {
    padding: 0.25rem;
    --size: calc(var(--size-selector, 0.25rem) * 6);
  }
  .checkbox-sm {
    padding: 0.1875rem;
    --size: calc(var(--size-selector, 0.25rem) * 5);
  }
  .checkbox-xl {
    padding: 0.375rem;
    --size: calc(var(--size-selector, 0.25rem) * 8);
  }
  .checkbox-xs {
    padding: 0.125rem;
    --size: calc(var(--size-selector, 0.25rem) * 4);
  }
  .radio-lg {
    padding: 0.3125rem;
    &:is([type="radio"]) {
      --size: calc(var(--size-selector, 0.25rem) * 7);
    }
  }
  .radio-md {
    padding: 0.25rem;
    &:is([type="radio"]) {
      --size: calc(var(--size-selector, 0.25rem) * 6);
    }
  }
  .radio-sm {
    padding: 0.1875rem;
    &:is([type="radio"]) {
      --size: calc(var(--size-selector, 0.25rem) * 5);
    }
  }
  .radio-xl {
    padding: 0.375rem;
    &:is([type="radio"]) {
      --size: calc(var(--size-selector, 0.25rem) * 8);
    }
  }
  .radio-xs {
    padding: 0.125rem;
    &:is([type="radio"]) {
      --size: calc(var(--size-selector, 0.25rem) * 4);
    }
  }
  .p-0 {
    padding: calc(var(--spacing) * 0);
  }
  .p-0\.5 {
    padding: calc(var(--spacing) * 0.5);
  }
  .p-1 {
    padding: calc(var(--spacing) * 1);
  }
  .p-1\.5 {
    padding: calc(var(--spacing) * 1.5);
  }
  .p-2 {
    padding: calc(var(--spacing) * 2);
  }
  .p-2\.5 {
    padding: calc(var(--spacing) * 2.5);
  }
  .p-3 {
    padding: calc(var(--spacing) * 3);
  }
  .p-3\.5 {
    padding: calc(var(--spacing) * 3.5);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .p-5 {
    padding: calc(var(--spacing) * 5);
  }
  .p-6 {
    padding: calc(var(--spacing) * 6);
  }
  .p-8 {
    padding: calc(var(--spacing) * 8);
  }
  .p-10 {
    padding: calc(var(--spacing) * 10);
  }
  .p-12 {
    padding: calc(var(--spacing) * 12);
  }
  .menu-title {
    padding-inline: calc(0.25rem * 3);
    padding-block: calc(0.25rem * 2);
    color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-base-content) 40%, transparent);
    }
    font-size: 0.875rem;
    font-weight: 600;
  }
  .table-lg {
    :not(thead, tfoot) tr {
      font-size: 1.125rem;
    }
    :where(th, td) {
      padding-inline: calc(0.25rem * 5);
      padding-block: calc(0.25rem * 4);
    }
  }
  .table-md {
    :not(thead, tfoot) tr {
      font-size: 0.875rem;
    }
    :where(th, td) {
      padding-inline: calc(0.25rem * 4);
      padding-block: calc(0.25rem * 3);
    }
  }
  .table-sm {
    :not(thead, tfoot) tr {
      font-size: 0.75rem;
    }
    :where(th, td) {
      padding-inline: calc(0.25rem * 3);
      padding-block: calc(0.25rem * 2);
    }
  }
  .table-xl {
    :not(thead, tfoot) tr {
      font-size: 1.375rem;
    }
    :where(th, td) {
      padding-inline: calc(0.25rem * 6);
      padding-block: calc(0.25rem * 5);
    }
  }
  .table-xs {
    :not(thead, tfoot) tr {
      font-size: 0.6875rem;
    }
    :where(th, td) {
      padding-inline: calc(0.25rem * 2);
      padding-block: calc(0.25rem * 1);
    }
  }
  .badge-lg {
    --size: calc(var(--size-selector, 0.25rem) * 7);
    font-size: 1rem;
    padding-inline: calc(0.25rem * 3.5 - var(--border));
  }
  .badge-md {
    --size: calc(var(--size-selector, 0.25rem) * 6);
    font-size: 0.875rem;
    padding-inline: calc(0.25rem * 3 - var(--border));
  }
  .badge-sm {
    --size: calc(var(--size-selector, 0.25rem) * 5);
    font-size: 0.75rem;
    padding-inline: calc(0.25rem * 2.5 - var(--border));
  }
  .badge-xl {
    --size: calc(var(--size-selector, 0.25rem) * 8);
    font-size: 1.125rem;
    padding-inline: calc(0.25rem * 4 - var(--border));
  }
  .badge-xs {
    --size: calc(var(--size-selector, 0.25rem) * 4);
    font-size: 0.625rem;
    padding-inline: calc(0.25rem * 2 - var(--border));
  }
  .px-1 {
    padding-inline: calc(var(--spacing) * 1);
  }
  .px-1\.5 {
    padding-inline: calc(var(--spacing) * 1.5);
  }
  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }
  .px-2\.5 {
    padding-inline: calc(var(--spacing) * 2.5);
  }
  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }
  .px-3\.5 {
    padding-inline: calc(var(--spacing) * 3.5);
  }
  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .px-5 {
    padding-inline: calc(var(--spacing) * 5);
  }
  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }
  .px-7 {
    padding-inline: calc(var(--spacing) * 7);
  }
  .px-8 {
    padding-inline: calc(var(--spacing) * 8);
  }
  .py-0\.5 {
    padding-block: calc(var(--spacing) * 0.5);
  }
  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }
  .py-1\.5 {
    padding-block: calc(var(--spacing) * 1.5);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .py-2\.5 {
    padding-block: calc(var(--spacing) * 2.5);
  }
  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }
  .py-3\.5 {
    padding-block: calc(var(--spacing) * 3.5);
  }
  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }
  .py-5 {
    padding-block: calc(var(--spacing) * 5);
  }
  .py-6 {
    padding-block: calc(var(--spacing) * 6);
  }
  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }
  .py-10 {
    padding-block: calc(var(--spacing) * 10);
  }
  .py-12 {
    padding-block: calc(var(--spacing) * 12);
  }
  .py-16 {
    padding-block: calc(var(--spacing) * 16);
  }
  .py-20 {
    padding-block: calc(var(--spacing) * 20);
  }
  .file-input-xl {
    padding-inline-end: calc(0.25rem * 6);
    --size: calc(var(--size-field, 0.25rem) * 14);
    font-size: 1.125rem;
    line-height: 3rem;
    &::file-selector-button {
      font-size: 1.375rem;
    }
  }
  .pt-1 {
    padding-top: calc(var(--spacing) * 1);
  }
  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }
  .pt-3 {
    padding-top: calc(var(--spacing) * 3);
  }
  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }
  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }
  .pt-12 {
    padding-top: calc(var(--spacing) * 12);
  }
  .pt-24 {
    padding-top: calc(var(--spacing) * 24);
  }
  .pr-3 {
    padding-right: calc(var(--spacing) * 3);
  }
  .pr-9 {
    padding-right: calc(var(--spacing) * 9);
  }
  .pb-1 {
    padding-bottom: calc(var(--spacing) * 1);
  }
  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }
  .pb-3 {
    padding-bottom: calc(var(--spacing) * 3);
  }
  .pb-4 {
    padding-bottom: calc(var(--spacing) * 4);
  }
  .pb-6 {
    padding-bottom: calc(var(--spacing) * 6);
  }
  .pb-8 {
    padding-bottom: calc(var(--spacing) * 8);
  }
  .pb-16 {
    padding-bottom: calc(var(--spacing) * 16);
  }
  .pb-20 {
    padding-bottom: calc(var(--spacing) * 20);
  }
  .pl-0 {
    padding-left: calc(var(--spacing) * 0);
  }
  .pl-1 {
    padding-left: calc(var(--spacing) * 1);
  }
  .pl-3 {
    padding-left: calc(var(--spacing) * 3);
  }
  .pl-6 {
    padding-left: calc(var(--spacing) * 6);
  }
  .pl-7 {
    padding-left: calc(var(--spacing) * 7);
  }
  .pl-9 {
    padding-left: calc(var(--spacing) * 9);
  }
  .text-center {
    text-align: center;
  }
  .text-left {
    text-align: left;
  }
  .text-right {
    text-align: right;
  }
  .align-bottom {
    vertical-align: bottom;
  }
  .align-middle {
    vertical-align: middle;
  }
  .font-mono {
    font-family: var(--font-mono);
  }
  .font-sans {
    font-family: var(--font-sans);
  }
  .file-input-lg {
    --size: calc(var(--size-field, 0.25rem) * 12);
    font-size: 1.125rem;
    line-height: 2.5rem;
    &::file-selector-button {
      font-size: 1.125rem;
    }
  }
  .file-input-md {
    --size: calc(var(--size-field, 0.25rem) * 10);
    font-size: 0.875rem;
    line-height: 2;
    &::file-selector-button {
      font-size: 0.875rem;
    }
  }
  .file-input-sm {
    --size: calc(var(--size-field, 0.25rem) * 8);
    font-size: 0.75rem;
    line-height: 1.5rem;
    &::file-selector-button {
      font-size: 0.75rem;
    }
  }
  .file-input-xs {
    --size: calc(var(--size-field, 0.25rem) * 6);
    font-size: 0.6875rem;
    line-height: 1rem;
    &::file-selector-button {
      font-size: 0.6875rem;
    }
  }
  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }
  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }
  .text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--tw-leading, var(--text-4xl--line-height));
  }
  .text-5xl {
    font-size: var(--text-5xl);
    line-height: var(--tw-leading, var(--text-5xl--line-height));
  }
  .text-7xl {
    font-size: var(--text-7xl);
    line-height: var(--tw-leading, var(--text-7xl--line-height));
  }
  .text-9xl {
    font-size: var(--text-9xl);
    line-height: var(--tw-leading, var(--text-9xl--line-height));
  }
  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }
  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }
  .kbd-lg {
    --size: calc(var(--size-selector, 0.25rem) * 7);
    font-size: 1rem;
  }
  .kbd-md {
    --size: calc(var(--size-selector, 0.25rem) * 6);
    font-size: 0.875rem;
  }
  .kbd-sm {
    --size: calc(var(--size-selector, 0.25rem) * 5);
    font-size: 0.75rem;
  }
  .kbd-xl {
    --size: calc(var(--size-selector, 0.25rem) * 8);
    font-size: 1.125rem;
  }
  .kbd-xs {
    --size: calc(var(--size-selector, 0.25rem) * 4);
    font-size: 0.625rem;
  }
  .select-lg {
    --size: calc(var(--size-field, 0.25rem) * 12);
    font-size: 1.125rem;
  }
  .select-md {
    --size: calc(var(--size-field, 0.25rem) * 10);
    font-size: 0.875rem;
  }
  .select-sm {
    --size: calc(var(--size-field, 0.25rem) * 8);
    font-size: 0.75rem;
  }
  .select-xl {
    --size: calc(var(--size-field, 0.25rem) * 14);
    font-size: 1.375rem;
  }
  .select-xs {
    --size: calc(var(--size-field, 0.25rem) * 6);
    font-size: 0.6875rem;
  }
  .text-\[9px\] {
    font-size: 9px;
  }
  .text-\[10px\] {
    font-size: 10px;
  }
  .text-\[11px\] {
    font-size: 11px;
  }
  .textarea-lg {
    font-size: 1.125rem;
  }
  .textarea-md {
    font-size: 0.875rem;
  }
  .textarea-sm {
    font-size: 0.75rem;
  }
  .textarea-xl {
    font-size: 1.375rem;
  }
  .textarea-xs {
    font-size: 0.6875rem;
  }
  .leading-6 {
    --tw-leading: calc(var(--spacing) * 6);
    line-height: calc(var(--spacing) * 6);
  }
  .leading-8 {
    --tw-leading: calc(var(--spacing) * 8);
    line-height: calc(var(--spacing) * 8);
  }
  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  .leading-snug {
    --tw-leading: var(--leading-snug);
    line-height: var(--leading-snug);
  }
  .leading-tight {
    --tw-leading: var(--leading-tight);
    line-height: var(--leading-tight);
  }
  .font-black {
    --tw-font-weight: var(--font-weight-black);
    font-weight: var(--font-weight-black);
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .font-extrabold {
    --tw-font-weight: var(--font-weight-extrabold);
    font-weight: var(--font-weight-extrabold);
  }
  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .font-normal {
    --tw-font-weight: var(--font-weight-normal);
    font-weight: var(--font-weight-normal);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .tracking-tight {
    --tw-tracking: var(--tracking-tight);
    letter-spacing: var(--tracking-tight);
  }
  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }
  .tracking-wider {
    --tw-tracking: var(--tracking-wider);
    letter-spacing: var(--tracking-wider);
  }
  .tracking-widest {
    --tw-tracking: var(--tracking-widest);
    letter-spacing: var(--tracking-widest);
  }
  .text-wrap {
    text-wrap: wrap;
  }
  .break-words {
    overflow-wrap: break-word;
  }
  .whitespace-nowrap {
    white-space: nowrap;
  }
  .whitespace-pre-line {
    white-space: pre-line;
  }
  .whitespace-pre-wrap {
    white-space: pre-wrap;
  }
  .file-input-accent {
    --btn-color: var(--color-accent);
    &::file-selector-button {
      color: var(--color-accent-content);
    }
    &, &:focus, &:focus-within {
      --input-color: var(--color-accent);
    }
  }
  .file-input-error {
    --btn-color: var(--color-error);
    &::file-selector-button {
      color: var(--color-error-content);
    }
    &, &:focus, &:focus-within {
      --input-color: var(--color-error);
    }
  }
  .file-input-info {
    --btn-color: var(--color-info);
    &::file-selector-button {
      color: var(--color-info-content);
    }
    &, &:focus, &:focus-within {
      --input-color: var(--color-info);
    }
  }
  .file-input-neutral {
    --btn-color: var(--color-neutral);
    &::file-selector-button {
      color: var(--color-neutral-content);
    }
    &, &:focus, &:focus-within {
      --input-color: var(--color-neutral);
    }
  }
  .file-input-primary {
    --btn-color: var(--color-primary);
    &::file-selector-button {
      color: var(--color-primary-content);
    }
    &, &:focus, &:focus-within {
      --input-color: var(--color-primary);
    }
  }
  .file-input-secondary {
    --btn-color: var(--color-secondary);
    &::file-selector-button {
      color: var(--color-secondary-content);
    }
    &, &:focus, &:focus-within {
      --input-color: var(--color-secondary);
    }
  }
  .file-input-success {
    --btn-color: var(--color-success);
    &::file-selector-button {
      color: var(--color-success-content);
    }
    &, &:focus, &:focus-within {
      --input-color: var(--color-success);
    }
  }
  .file-input-warning {
    --btn-color: var(--color-warning);
    &::file-selector-button {
      color: var(--color-warning-content);
    }
    &, &:focus, &:focus-within {
      --input-color: var(--color-warning);
    }
  }
  .checkbox-accent {
    color: var(--color-accent-content);
    --input-color: var(--color-accent);
  }
  .checkbox-error {
    color: var(--color-error-content);
    --input-color: var(--color-error);
  }
  .checkbox-info {
    color: var(--color-info-content);
    --input-color: var(--color-info);
  }
  .checkbox-neutral {
    color: var(--color-neutral-content);
    --input-color: var(--color-neutral);
  }
  .checkbox-primary {
    color: var(--color-primary-content);
    --input-color: var(--color-primary);
  }
  .checkbox-secondary {
    color: var(--color-secondary-content);
    --input-color: var(--color-secondary);
  }
  .checkbox-success {
    color: var(--color-success-content);
    --input-color: var(--color-success);
  }
  .checkbox-warning {
    color: var(--color-warning-content);
    --input-color: var(--color-warning);
  }
  .link-accent {
    color: var(--color-accent);
    @media (hover: hover) {
      &:hover {
        color: var(--color-accent);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-accent) 80%, #000);
        }
      }
    }
  }
  .link-error {
    color: var(--color-error);
    @media (hover: hover) {
      &:hover {
        color: var(--color-error);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-error) 80%, #000);
        }
      }
    }
  }
  .link-info {
    color: var(--color-info);
    @media (hover: hover) {
      &:hover {
        color: var(--color-info);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-info) 80%, #000);
        }
      }
    }
  }
  .link-neutral {
    color: var(--color-neutral);
    @media (hover: hover) {
      &:hover {
        color: var(--color-neutral);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-neutral) 80%, #000);
        }
      }
    }
  }
  .link-primary {
    color: var(--color-primary);
    @media (hover: hover) {
      &:hover {
        color: var(--color-primary);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-primary) 80%, #000);
        }
      }
    }
  }
  .link-secondary {
    color: var(--color-secondary);
    @media (hover: hover) {
      &:hover {
        color: var(--color-secondary);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-secondary) 80%, #000);
        }
      }
    }
  }
  .link-success {
    color: var(--color-success);
    @media (hover: hover) {
      &:hover {
        color: var(--color-success);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-success) 80%, #000);
        }
      }
    }
  }
  .link-warning {
    color: var(--color-warning);
    @media (hover: hover) {
      &:hover {
        color: var(--color-warning);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-warning) 80%, #000);
        }
      }
    }
  }
  .range-accent {
    color: var(--color-accent);
    --range-thumb: var(--color-accent-content);
  }
  .range-error {
    color: var(--color-error);
    --range-thumb: var(--color-error-content);
  }
  .range-info {
    color: var(--color-info);
    --range-thumb: var(--color-info-content);
  }
  .range-neutral {
    color: var(--color-neutral);
    --range-thumb: var(--color-neutral-content);
  }
  .range-primary {
    color: var(--color-primary);
    --range-thumb: var(--color-primary-content);
  }
  .range-secondary {
    color: var(--color-secondary);
    --range-thumb: var(--color-secondary-content);
  }
  .range-success {
    color: var(--color-success);
    --range-thumb: var(--color-success-content);
  }
  .range-warning {
    color: var(--color-warning);
    --range-thumb: var(--color-warning-content);
  }
  .tooltip-accent {
    --tt-bg: var(--color-accent);
    > .tooltip-content, &[data-tip]:before {
      color: var(--color-accent-content);
    }
  }
  .tooltip-error {
    --tt-bg: var(--color-error);
    > .tooltip-content, &[data-tip]:before {
      color: var(--color-error-content);
    }
  }
  .tooltip-info {
    --tt-bg: var(--color-info);
    > .tooltip-content, &[data-tip]:before {
      color: var(--color-info-content);
    }
  }
  .tooltip-primary {
    --tt-bg: var(--color-primary);
    > .tooltip-content, &[data-tip]:before {
      color: var(--color-primary-content);
    }
  }
  .tooltip-secondary {
    --tt-bg: var(--color-secondary);
    > .tooltip-content, &[data-tip]:before {
      color: var(--color-secondary-content);
    }
  }
  .tooltip-success {
    --tt-bg: var(--color-success);
    > .tooltip-content, &[data-tip]:before {
      color: var(--color-success-content);
    }
  }
  .tooltip-warning {
    --tt-bg: var(--color-warning);
    > .tooltip-content, &[data-tip]:before {
      color: var(--color-warning-content);
    }
  }
  .progress-accent {
    color: var(--color-accent);
  }
  .progress-error {
    color: var(--color-error);
  }
  .progress-info {
    color: var(--color-info);
  }
  .progress-neutral {
    color: var(--color-neutral);
  }
  .progress-primary {
    color: var(--color-primary);
  }
  .progress-secondary {
    color: var(--color-secondary);
  }
  .progress-success {
    color: var(--color-success);
  }
  .progress-warning {
    color: var(--color-warning);
  }
  .text-\[\#8E8E93\] {
    color: #8E8E93;
  }
  .text-amber-500 {
    color: var(--color-amber-500);
  }
  .text-amber-600 {
    color: var(--color-amber-600);
  }
  .text-amber-700 {
    color: var(--color-amber-700);
  }
  .text-amber-800 {
    color: var(--color-amber-800);
  }
  .text-base-content\/70 {
    color: var(--color-base-content);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-base-content) 70%, transparent);
    }
  }
  .text-blue-300 {
    color: var(--color-blue-300);
  }
  .text-blue-500 {
    color: var(--color-blue-500);
  }
  .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-500 {
    color: var(--color-emerald-500);
  }
  .text-emerald-600 {
    color: var(--color-emerald-600);
  }
  .text-emerald-700 {
    color: var(--color-emerald-700);
  }
  .text-emerald-800 {
    color: var(--color-emerald-800);
  }
  .text-emerald-900 {
    color: var(--color-emerald-900);
  }
  .text-error {
    color: var(--color-error);
  }
  .text-gray-400 {
    color: var(--color-gray-400);
  }
  .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-900 {
    color: var(--color-gray-900);
  }
  .text-green-100 {
    color: var(--color-green-100);
  }
  .text-green-200 {
    color: var(--color-green-200);
  }
  .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-green-900 {
    color: var(--color-green-900);
  }
  .text-indigo-100 {
    color: var(--color-indigo-100);
  }
  .text-indigo-200 {
    color: var(--color-indigo-200);
  }
  .text-indigo-600 {
    color: var(--color-indigo-600);
  }
  .text-indigo-700 {
    color: var(--color-indigo-700);
  }
  .text-indigo-900 {
    color: var(--color-indigo-900);
  }
  .text-manifest-bg-muted {
    color: var(--color-manifest-bg-muted);
  }
  .text-manifest-border {
    color: var(--color-manifest-border);
  }
  .text-manifest-cat-dark {
    color: var(--color-manifest-cat-dark);
  }
  .text-manifest-danger {
    color: var(--color-manifest-danger);
  }
  .text-manifest-info {
    color: var(--color-manifest-info);
  }
  .text-manifest-primary {
    color: var(--color-manifest-primary);
  }
  .text-manifest-primary-dark {
    color: var(--color-manifest-primary-dark);
  }
  .text-manifest-secondary {
    color: var(--color-manifest-secondary);
  }
  .text-manifest-success {
    color: var(--color-manifest-success);
  }
  .text-manifest-success-dark {
    color: var(--color-manifest-success-dark);
  }
  .text-manifest-text {
    color: var(--color-manifest-text);
  }
  .text-manifest-text-light {
    color: var(--color-manifest-text-light);
  }
  .text-manifest-text-muted {
    color: var(--color-manifest-text-muted);
  }
  .text-manifest-warning {
    color: var(--color-manifest-warning);
  }
  .text-neutral-content {
    color: var(--color-neutral-content);
  }
  .text-orange-600 {
    color: var(--color-orange-600);
  }
  .text-orange-700 {
    color: var(--color-orange-700);
  }
  .text-orange-800 {
    color: var(--color-orange-800);
  }
  .text-pink-500 {
    color: var(--color-pink-500);
  }
  .text-pink-600 {
    color: var(--color-pink-600);
  }
  .text-pink-700 {
    color: var(--color-pink-700);
  }
  .text-primary {
    color: var(--color-primary);
  }
  .text-purple-600 {
    color: var(--color-purple-600);
  }
  .text-purple-700 {
    color: var(--color-purple-700);
  }
  .text-purple-800 {
    color: var(--color-purple-800);
  }
  .text-red-400 {
    color: var(--color-red-400);
  }
  .text-red-500 {
    color: var(--color-red-500);
  }
  .text-red-600 {
    color: var(--color-red-600);
  }
  .text-red-700 {
    color: var(--color-red-700);
  }
  .text-secondary {
    color: var(--color-secondary);
  }
  .text-slate-700 {
    color: var(--color-slate-700);
  }
  .text-teal-400 {
    color: var(--color-teal-400);
  }
  .text-teal-500 {
    color: var(--color-teal-500);
  }
  .text-teal-600 {
    color: var(--color-teal-600);
  }
  .text-teal-700 {
    color: var(--color-teal-700);
  }
  .text-teal-900 {
    color: var(--color-teal-900);
  }
  .text-violet-600 {
    color: var(--color-violet-600);
  }
  .text-white {
    color: var(--color-white);
  }
  .text-white\/40 {
    color: color-mix(in srgb, #fff 40%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 40%, transparent);
    }
  }
  .text-white\/50 {
    color: color-mix(in srgb, #fff 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 50%, transparent);
    }
  }
  .text-white\/80 {
    color: color-mix(in srgb, #fff 80%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 80%, transparent);
    }
  }
  .text-white\/90 {
    color: color-mix(in srgb, #fff 90%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 90%, transparent);
    }
  }
  .text-yellow-400 {
    color: var(--color-yellow-400);
  }
  .text-yellow-500 {
    color: var(--color-yellow-500);
  }
  .text-yellow-600 {
    color: var(--color-yellow-600);
  }
  .text-yellow-700 {
    color: var(--color-yellow-700);
  }
  .text-yellow-800 {
    color: var(--color-yellow-800);
  }
  .text-yellow-900 {
    color: var(--color-yellow-900);
  }
  .capitalize {
    text-transform: capitalize;
  }
  .uppercase {
    text-transform: uppercase;
  }
  .italic {
    font-style: italic;
  }
  .tabular-nums {
    --tw-numeric-spacing: tabular-nums;
    font-variant-numeric: var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,);
  }
  .btn-link {
    text-decoration-line: underline;
    outline-color: currentColor;
    --btn-border: #0000;
    --btn-bg: #0000;
    --btn-fg: var(--color-primary);
    --btn-noise: none;
    --btn-shadow: "";
    &:is(.btn-active, :hover, :active:focus, :focus-visible) {
      text-decoration-line: underline;
      --btn-border: #0000;
      --btn-bg: #0000;
    }
  }
  .link-hover {
    text-decoration-line: none;
    &:hover {
      @media (hover: hover) {
        text-decoration-line: underline;
      }
    }
  }
  .line-through {
    text-decoration-line: line-through;
  }
  .no-underline {
    text-decoration-line: none;
  }
  .underline {
    text-decoration-line: underline;
  }
  .placeholder-manifest-text-muted {
    &::placeholder {
      color: var(--color-manifest-text-muted);
    }
  }
  .swap-active {
    .swap-off {
      opacity: 0%;
    }
    .swap-on {
      opacity: 100%;
    }
  }
  .opacity-0 {
    opacity: 0%;
  }
  .opacity-25 {
    opacity: 25%;
  }
  .opacity-40 {
    opacity: 40%;
  }
  .opacity-50 {
    opacity: 50%;
  }
  .opacity-60 {
    opacity: 60%;
  }
  .opacity-70 {
    opacity: 70%;
  }
  .opacity-75 {
    opacity: 75%;
  }
  .opacity-80 {
    opacity: 80%;
  }
  .opacity-90 {
    opacity: 90%;
  }
  .opacity-100 {
    opacity: 100%;
  }
  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-2xl {
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, rgb(0 0 0 / 0.25));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-md {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-sm {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-xl {
    --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .ring-1 {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .ring-2 {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-indigo-500\/25 {
    --tw-shadow-color: color-mix(in srgb, oklch(58.5% 0.233 277.117) 25%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-shadow-color: color-mix(in oklab, color-mix(in oklab, var(--color-indigo-500) 25%, transparent) var(--tw-shadow-alpha), transparent);
    }
  }
  .ring-amber-200 {
    --tw-ring-color: var(--color-amber-200);
  }
  .ring-black {
    --tw-ring-color: var(--color-black);
  }
  .ring-green-200 {
    --tw-ring-color: var(--color-green-200);
  }
  .ring-indigo-200 {
    --tw-ring-color: var(--color-indigo-200);
  }
  .ring-white {
    --tw-ring-color: var(--color-white);
  }
  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }
  .btn-ghost {
    &:not(.btn-active, :hover, :active:focus, :focus-visible) {
      --btn-shadow: "";
      --btn-bg: #0000;
      --btn-border: #0000;
      --btn-noise: none;
      &:not(:disabled, [disabled], .btn-disabled) {
        outline-color: currentColor;
        --btn-fg: currentColor;
      }
    }
  }
  .blur-xl {
    --tw-blur: blur(var(--blur-xl));
    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,);
  }
  .brightness-200 {
    --tw-brightness: brightness(200%);
    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,);
  }
  .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-md {
    --tw-backdrop-blur: blur(var(--blur-md));
    -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .backdrop-blur-sm {
    --tw-backdrop-blur: blur(var(--blur-sm));
    -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .backdrop-blur-xl {
    --tw-backdrop-blur: blur(var(--blur-xl));
    -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .backdrop-filter {
    -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, visibility, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-\[left\] {
    transition-property: left;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-\[margin\] {
    transition-property: margin;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-shadow {
    transition-property: box-shadow;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .duration-75 {
    --tw-duration: 75ms;
    transition-duration: 75ms;
  }
  .duration-100 {
    --tw-duration: 100ms;
    transition-duration: 100ms;
  }
  .duration-150 {
    --tw-duration: 150ms;
    transition-duration: 150ms;
  }
  .duration-200 {
    --tw-duration: 200ms;
    transition-duration: 200ms;
  }
  .duration-300 {
    --tw-duration: 300ms;
    transition-duration: 300ms;
  }
  .duration-500 {
    --tw-duration: 500ms;
    transition-duration: 500ms;
  }
  .ease-in {
    --tw-ease: var(--ease-in);
    transition-timing-function: var(--ease-in);
  }
  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }
  .ease-out {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-out);
  }
  .tabs-bottom {
    --tabs-height: auto;
    --tabs-direction: row;
    .tab {
      --tab-order: 1;
      --tab-border: var(--border) 0 0 0;
      --tab-radius-ss: 0;
      --tab-radius-se: 0;
      --tab-radius-es: min(var(--radius-field), var(--tab-radius-min));
      --tab-radius-ee: min(var(--radius-field), var(--tab-radius-min));
      --tab-border-colors: var(--tab-border-color) #0000 #0000 #0000;
      --tab-paddings: 0 var(--tab-p) var(--border) var(--tab-p);
      --tab-corner-width: calc(100% + min(var(--radius-field), var(--tab-radius-min)) * 2);
      --tab-corner-height: min(var(--radius-field), var(--tab-radius-min));
      --tab-corner-position: top left, top right;
      &:is(.tab-active, [aria-selected="true"]):not(.tab-disabled, [disabled]), &:is(input:checked), &:is(label:has(:checked)) {
        --tab-border: 0 var(--border) var(--border) var(--border);
        --tab-border-colors: #0000 var(--tab-border-color) var(--tab-border-color)
        var(--tab-border-color);
        --tab-paddings: var(--border) calc(var(--tab-p) - var(--border)) 0
        calc(var(--tab-p) - var(--border));
        --tab-inset: 0 auto auto auto;
        --radius-start: radial-gradient(
        circle at bottom left,
        #0000 var(--tab-grad),
        var(--tab-border-color) calc(var(--tab-grad) + 0.25px),
        var(--tab-border-color) calc(var(--tab-grad) + var(--border)),
        var(--tab-bg) calc(var(--tab-grad) + var(--border) + 0.25px)
      );
        --radius-end: radial-gradient(
        circle at bottom right,
        #0000 var(--tab-grad),
        var(--tab-border-color) calc(var(--tab-grad) + 0.25px),
        var(--tab-border-color) calc(var(--tab-grad) + var(--border)),
        var(--tab-bg) calc(var(--tab-grad) + var(--border) + 0.25px)
      );
      }
    }
    &:has(.tab-content) {
      > .tab:first-child {
        &:not(.tab-active, [aria-selected="true"]) {
          --tab-border-colors: #0000 var(--tab-border-color) var(--tab-border-color)
          var(--tab-border-color);
        }
      }
    }
    .tab-content {
      --tabcontent-order: 0;
      --tabcontent-margin: 0 0 calc(-1 * var(--border)) 0;
      --tabcontent-radius-ss: var(--radius-box);
      --tabcontent-radius-se: var(--radius-box);
      --tabcontent-radius-es: 0;
      --tabcontent-radius-ee: var(--radius-box);
    }
    :checked, :is(label:has(:checked)), :is(.tab-active, [aria-selected="true"]) {
      & + .tab-content:not(:nth-child(2)) {
        --tabcontent-radius-es: var(--radius-box);
      }
    }
  }
  .tabs-top {
    --tabs-height: auto;
    --tabs-direction: row;
    .tab {
      --tab-order: 0;
      --tab-border: 0 0 var(--border) 0;
      --tab-radius-ss: min(var(--radius-field), var(--tab-radius-min));
      --tab-radius-se: min(var(--radius-field), var(--tab-radius-min));
      --tab-radius-es: 0;
      --tab-radius-ee: 0;
      --tab-paddings: var(--border) var(--tab-p) 0 var(--tab-p);
      --tab-border-colors: #0000 #0000 var(--tab-border-color) #0000;
      --tab-corner-width: calc(100% + min(var(--radius-field), var(--tab-radius-min)) * 2);
      --tab-corner-height: min(var(--radius-field), var(--tab-radius-min));
      --tab-corner-position: top left, top right;
      &:is(.tab-active, [aria-selected="true"]):not(.tab-disabled, [disabled]), &:is(input:checked), &:is(label:has(:checked)) {
        --tab-border: var(--border) var(--border) 0 var(--border);
        --tab-border-colors: var(--tab-border-color) var(--tab-border-color) #0000
        var(--tab-border-color);
        --tab-paddings: 0 calc(var(--tab-p) - var(--border)) var(--border)
        calc(var(--tab-p) - var(--border));
        --tab-inset: auto auto 0 auto;
        --radius-start: radial-gradient(
        circle at top left,
        #0000 var(--tab-grad),
        var(--tab-border-color) calc(var(--tab-grad) + 0.25px),
        var(--tab-border-color) calc(var(--tab-grad) + var(--border)),
        var(--tab-bg) calc(var(--tab-grad) + var(--border) + 0.25px)
      );
        --radius-end: radial-gradient(
        circle at top right,
        #0000 var(--tab-grad),
        var(--tab-border-color) calc(var(--tab-grad) + 0.25px),
        var(--tab-border-color) calc(var(--tab-grad) + var(--border)),
        var(--tab-bg) calc(var(--tab-grad) + var(--border) + 0.25px)
      );
      }
    }
    &:has(.tab-content) {
      > .tab:first-child {
        &:not(.tab-active, [aria-selected="true"]) {
          --tab-border-colors: var(--tab-border-color) var(--tab-border-color) #0000
          var(--tab-border-color);
        }
      }
    }
    .tab-content {
      --tabcontent-order: 1;
      --tabcontent-margin: calc(-1 * var(--border)) 0 0 0;
      --tabcontent-radius-ss: 0;
      --tabcontent-radius-se: var(--radius-box);
      --tabcontent-radius-es: var(--radius-box);
      --tabcontent-radius-ee: var(--radius-box);
    }
    :checked, label:has(:checked), :is(.tab-active, [aria-selected="true"]) {
      & + .tab-content {
        &:nth-child(1), &:nth-child(n + 3) {
          --tabcontent-radius-ss: var(--radius-box);
        }
      }
    }
  }
  .btn-outline {
    &:not( .btn-active, :hover, :active:focus, :focus-visible, :disabled, [disabled], .btn-disabled, :checked ) {
      --btn-shadow: "";
      --btn-bg: #0000;
      --btn-fg: var(--btn-color);
      --btn-border: var(--btn-color);
      --btn-noise: none;
    }
  }
  .btn-soft {
    &:not(.btn-active, :hover, :active:focus, :focus-visible, :disabled, [disabled], .btn-disabled) {
      --btn-shadow: "";
      --btn-fg: var(--btn-color, var(--color-base-content));
      --btn-bg: var(--btn-color, var(--color-base-content));
      @supports (color: color-mix(in lab, red, red)) {
        --btn-bg: color-mix(
      in oklab,
      var(--btn-color, var(--color-base-content)) 8%,
      var(--color-base-100)
    );
      }
      --btn-border: var(--btn-color, var(--color-base-content));
      @supports (color: color-mix(in lab, red, red)) {
        --btn-border: color-mix(
      in oklab,
      var(--btn-color, var(--color-base-content)) 10%,
      var(--color-base-100)
    );
      }
      --btn-noise: none;
    }
  }
  .indicator-center {
    --inidicator-s: 50%;
    --inidicator-e: 50%;
    --inidicator-x: -50%;
    [dir="rtl"] & {
      --inidicator-x: 50%;
    }
  }
  .btn-lg {
    --fontsize: 1.125rem;
    --btn-p: 1.25rem;
    --size: calc(var(--size-field, 0.25rem) * 12);
  }
  .btn-md {
    --fontsize: 0.875rem;
    --btn-p: 1rem;
    --size: calc(var(--size-field, 0.25rem) * 10);
  }
  .btn-sm {
    --fontsize: 0.75rem;
    --btn-p: 0.75rem;
    --size: calc(var(--size-field, 0.25rem) * 8);
  }
  .btn-xl {
    --fontsize: 1.375rem;
    --btn-p: 1.5rem;
    --size: calc(var(--size-field, 0.25rem) * 14);
  }
  .btn-xs {
    --fontsize: 0.6875rem;
    --btn-p: 0.5rem;
    --size: calc(var(--size-field, 0.25rem) * 6);
  }
  .card-lg {
    .card-body {
      --card-p: 2rem;
      --card-fs: 1rem;
    }
    .card-title {
      --cardtitle-fs: 1.25rem;
    }
  }
  .card-md {
    .card-body {
      --card-p: 1.5rem;
      --card-fs: 0.875rem;
    }
    .card-title {
      --cardtitle-fs: 1.125rem;
    }
  }
  .card-sm {
    .card-body {
      --card-p: 1rem;
      --card-fs: 0.75rem;
    }
    .card-title {
      --cardtitle-fs: 1rem;
    }
  }
  .card-xl {
    .card-body {
      --card-p: 2.5rem;
      --card-fs: 1.125rem;
    }
    .card-title {
      --cardtitle-fs: 1.375rem;
    }
  }
  .card-xs {
    .card-body {
      --card-p: 0.5rem;
      --card-fs: 0.6875rem;
    }
    .card-title {
      --cardtitle-fs: 0.875rem;
    }
  }
  .indicator-bottom {
    --inidicator-t: auto;
    --inidicator-b: 0;
    --indicator-y: 50%;
  }
  .indicator-end {
    --inidicator-s: auto;
    --inidicator-e: 0;
    --inidicator-x: 50%;
  }
  .indicator-middle {
    --inidicator-t: 50%;
    --inidicator-b: 50%;
    --indicator-y: -50%;
  }
  .indicator-start {
    --inidicator-s: 0;
    --inidicator-e: auto;
    --inidicator-x: -50%;
  }
  .indicator-top {
    --inidicator-t: 0;
    --inidicator-b: auto;
    --indicator-y: -50%;
  }
  .badge-accent {
    --badge-color: var(--color-accent);
    --badge-fg: var(--color-accent-content);
  }
  .badge-error {
    --badge-color: var(--color-error);
    --badge-fg: var(--color-error-content);
  }
  .badge-info {
    --badge-color: var(--color-info);
    --badge-fg: var(--color-info-content);
  }
  .badge-neutral {
    --badge-color: var(--color-neutral);
    --badge-fg: var(--color-neutral-content);
  }
  .badge-primary {
    --badge-color: var(--color-primary);
    --badge-fg: var(--color-primary-content);
  }
  .badge-secondary {
    --badge-color: var(--color-secondary);
    --badge-fg: var(--color-secondary-content);
  }
  .badge-success {
    --badge-color: var(--color-success);
    --badge-fg: var(--color-success-content);
  }
  .badge-warning {
    --badge-color: var(--color-warning);
    --badge-fg: var(--color-warning-content);
  }
  .btn-accent {
    --btn-color: var(--color-accent);
    --btn-fg: var(--color-accent-content);
  }
  .btn-error {
    --btn-color: var(--color-error);
    --btn-fg: var(--color-error-content);
  }
  .btn-info {
    --btn-color: var(--color-info);
    --btn-fg: var(--color-info-content);
  }
  .btn-neutral {
    --btn-color: var(--color-neutral);
    --btn-fg: var(--color-neutral-content);
  }
  .btn-primary {
    --btn-color: var(--color-primary);
    --btn-fg: var(--color-primary-content);
  }
  .btn-secondary {
    --btn-color: var(--color-secondary);
    --btn-fg: var(--color-secondary-content);
  }
  .btn-success {
    --btn-color: var(--color-success);
    --btn-fg: var(--color-success-content);
  }
  .btn-warning {
    --btn-color: var(--color-warning);
    --btn-fg: var(--color-warning-content);
  }
  .outline-none {
    --tw-outline-style: none;
    outline-style: none;
  }
  .select-none {
    -webkit-user-select: none;
    user-select: none;
  }
  .timeline-snap-icon {
    > li {
      --timeline-col-start: 0.5rem;
      --timeline-row-start: minmax(0, 1fr);
    }
  }
  .toggle-lg {
    &:is([type="checkbox"]), &:has([type="checkbox"]) {
      --toggle-p: 0.25rem;
      --size: calc(var(--size-selector, 0.25rem) * 7);
    }
  }
  .toggle-md {
    &:is([type="checkbox"]), &:has([type="checkbox"]) {
      --toggle-p: 0.1875rem;
      --size: calc(var(--size-selector, 0.25rem) * 6);
    }
  }
  .toggle-sm {
    &:is([type="checkbox"]), &:has([type="checkbox"]) {
      --toggle-p: 0.125rem;
      --size: calc(var(--size-selector, 0.25rem) * 5);
    }
  }
  .toggle-xl {
    &:is([type="checkbox"]), &:has([type="checkbox"]) {
      --toggle-p: 0.3125rem;
      --size: calc(var(--size-selector, 0.25rem) * 8);
    }
  }
  .toggle-xs {
    &:is([type="checkbox"]), &:has([type="checkbox"]) {
      --toggle-p: 0.0625rem;
      --size: calc(var(--size-selector, 0.25rem) * 4);
    }
  }
  .input-accent {
    &, &:focus, &:focus-within {
      --input-color: var(--color-accent);
    }
  }
  .input-error {
    &, &:focus, &:focus-within {
      --input-color: var(--color-error);
    }
  }
  .input-info {
    &, &:focus, &:focus-within {
      --input-color: var(--color-info);
    }
  }
  .input-neutral {
    &, &:focus, &:focus-within {
      --input-color: var(--color-neutral);
    }
  }
  .input-primary {
    &, &:focus, &:focus-within {
      --input-color: var(--color-primary);
    }
  }
  .input-secondary {
    &, &:focus, &:focus-within {
      --input-color: var(--color-secondary);
    }
  }
  .input-success {
    &, &:focus, &:focus-within {
      --input-color: var(--color-success);
    }
  }
  .input-warning {
    &, &:focus, &:focus-within {
      --input-color: var(--color-warning);
    }
  }
  .radio-accent {
    --input-color: var(--color-accent);
  }
  .radio-error {
    --input-color: var(--color-error);
  }
  .radio-info {
    --input-color: var(--color-info);
  }
  .radio-neutral {
    --input-color: var(--color-neutral);
  }
  .radio-primary {
    --input-color: var(--color-primary);
  }
  .radio-secondary {
    --input-color: var(--color-secondary);
  }
  .radio-success {
    --input-color: var(--color-success);
  }
  .radio-warning {
    --input-color: var(--color-warning);
  }
  .range-lg {
    --range-thumb-size: calc(var(--size-selector, 0.25rem) * 7);
  }
  .range-md {
    --range-thumb-size: calc(var(--size-selector, 0.25rem) * 6);
  }
  .range-sm {
    --range-thumb-size: calc(var(--size-selector, 0.25rem) * 5);
  }
  .range-xl {
    --range-thumb-size: calc(var(--size-selector, 0.25rem) * 8);
  }
  .range-xs {
    --range-thumb-size: calc(var(--size-selector, 0.25rem) * 4);
  }
  .select-accent {
    &, &:focus, &:focus-within {
      --input-color: var(--color-accent);
    }
  }
  .select-error {
    &, &:focus, &:focus-within {
      --input-color: var(--color-error);
    }
  }
  .select-info {
    &, &:focus, &:focus-within {
      --input-color: var(--color-info);
    }
  }
  .select-neutral {
    &, &:focus, &:focus-within {
      --input-color: var(--color-neutral);
    }
  }
  .select-primary {
    &, &:focus, &:focus-within {
      --input-color: var(--color-primary);
    }
  }
  .select-secondary {
    &, &:focus, &:focus-within {
      --input-color: var(--color-secondary);
    }
  }
  .select-success {
    &, &:focus, &:focus-within {
      --input-color: var(--color-success);
    }
  }
  .select-warning {
    &, &:focus, &:focus-within {
      --input-color: var(--color-warning);
    }
  }
  .textarea-accent {
    &, &:focus, &:focus-within {
      --input-color: var(--color-accent);
    }
  }
  .textarea-error {
    &, &:focus, &:focus-within {
      --input-color: var(--color-error);
    }
  }
  .textarea-info {
    &, &:focus, &:focus-within {
      --input-color: var(--color-info);
    }
  }
  .textarea-neutral {
    &, &:focus, &:focus-within {
      --input-color: var(--color-neutral);
    }
  }
  .textarea-primary {
    &, &:focus, &:focus-within {
      --input-color: var(--color-primary);
    }
  }
  .textarea-secondary {
    &, &:focus, &:focus-within {
      --input-color: var(--color-secondary);
    }
  }
  .textarea-success {
    &, &:focus, &:focus-within {
      --input-color: var(--color-success);
    }
  }
  .textarea-warning {
    &, &:focus, &:focus-within {
      --input-color: var(--color-warning);
    }
  }
  .toggle-accent {
    &:checked, &[aria-checked="true"] {
      --input-color: var(--color-accent);
    }
  }
  .toggle-error {
    &:checked, &[aria-checked="true"] {
      --input-color: var(--color-error);
    }
  }
  .toggle-info {
    &:checked, &[aria-checked="true"] {
      --input-color: var(--color-info);
    }
  }
  .toggle-neutral {
    &:checked, &[aria-checked="true"] {
      --input-color: var(--color-neutral);
    }
  }
  .toggle-primary {
    &:checked, &[aria-checked="true"] {
      --input-color: var(--color-primary);
    }
  }
  .toggle-secondary {
    &:checked, &[aria-checked="true"] {
      --input-color: var(--color-secondary);
    }
  }
  .toggle-success {
    &:checked, &[aria-checked="true"] {
      --input-color: var(--color-success);
    }
  }
  .toggle-warning {
    &:checked, &[aria-checked="true"] {
      --input-color: var(--color-warning);
    }
  }
  .group-open\:rotate-180 {
    &:is(:where(.group):is([open], :popover-open, :open) *) {
      rotate: 180deg;
    }
  }
  .group-hover\:text-manifest-primary {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: var(--color-manifest-primary);
      }
    }
  }
  .group-hover\:text-manifest-text {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: var(--color-manifest-text);
      }
    }
  }
  .group-hover\:opacity-70 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        opacity: 70%;
      }
    }
  }
  .group-hover\:opacity-100 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        opacity: 100%;
      }
    }
  }
  .last\:border-b-0 {
    &:last-child {
      border-bottom-style: var(--tw-border-style);
      border-bottom-width: 0px;
    }
  }
  .hover\:scale-105 {
    &:hover {
      @media (hover: hover) {
        --tw-scale-x: 105%;
        --tw-scale-y: 105%;
        --tw-scale-z: 105%;
        scale: var(--tw-scale-x) var(--tw-scale-y);
      }
    }
  }
  .hover\:scale-110 {
    &:hover {
      @media (hover: hover) {
        --tw-scale-x: 110%;
        --tw-scale-y: 110%;
        --tw-scale-z: 110%;
        scale: var(--tw-scale-x) var(--tw-scale-y);
      }
    }
  }
  .hover\:scale-125 {
    &:hover {
      @media (hover: hover) {
        --tw-scale-x: 125%;
        --tw-scale-y: 125%;
        --tw-scale-z: 125%;
        scale: var(--tw-scale-x) var(--tw-scale-y);
      }
    }
  }
  .hover\:scale-\[1\.02\] {
    &:hover {
      @media (hover: hover) {
        scale: 1.02;
      }
    }
  }
  .hover\:cursor-pointer {
    &:hover {
      @media (hover: hover) {
        cursor: pointer;
      }
    }
  }
  .hover\:border-amber-300 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-amber-300);
      }
    }
  }
  .hover\:border-emerald-300 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-emerald-300);
      }
    }
  }
  .hover\:border-indigo-200 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-indigo-200);
      }
    }
  }
  .hover\:border-indigo-300 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-indigo-300);
      }
    }
  }
  .hover\:border-manifest-accent-light {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-manifest-accent-light);
      }
    }
  }
  .hover\:border-manifest-border {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-manifest-border);
      }
    }
  }
  .hover\:border-manifest-danger {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-manifest-danger);
      }
    }
  }
  .hover\:border-manifest-primary {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-manifest-primary);
      }
    }
  }
  .hover\:border-manifest-primary\/30 {
    &:hover {
      @media (hover: hover) {
        border-color: color-mix(in srgb, #4F46E5 30%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          border-color: color-mix(in oklab, var(--color-manifest-primary) 30%, transparent);
        }
      }
    }
  }
  .hover\:border-orange-300 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-orange-300);
      }
    }
  }
  .hover\:border-pink-200 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-pink-200);
      }
    }
  }
  .hover\:border-teal-200 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-teal-200);
      }
    }
  }
  .hover\:bg-\[\#004182\] {
    &:hover {
      @media (hover: hover) {
        background-color: #004182;
      }
    }
  }
  .hover\:bg-amber-100 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-amber-100);
      }
    }
  }
  .hover\:bg-amber-100\/50 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, oklch(96.2% 0.059 95.617) 50%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-amber-100) 50%, transparent);
        }
      }
    }
  }
  .hover\:bg-black\/70 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, #000 70%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-black) 70%, transparent);
        }
      }
    }
  }
  .hover\:bg-blue-50 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-blue-50);
      }
    }
  }
  .hover\:bg-blue-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-blue-200);
      }
    }
  }
  .hover\:bg-blue-600 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-blue-600);
      }
    }
  }
  .hover\:bg-emerald-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-emerald-200);
      }
    }
  }
  .hover\:bg-emerald-700 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-emerald-700);
      }
    }
  }
  .hover\:bg-gray-50 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-50);
      }
    }
  }
  .hover\:bg-gray-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-200);
      }
    }
  }
  .hover\:bg-gray-400 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-400);
      }
    }
  }
  .hover\:bg-gray-800 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-800);
      }
    }
  }
  .hover\:bg-green-50 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-green-50);
      }
    }
  }
  .hover\:bg-green-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-green-200);
      }
    }
  }
  .hover\:bg-green-600 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-green-600);
      }
    }
  }
  .hover\:bg-green-700 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-green-700);
      }
    }
  }
  .hover\:bg-indigo-50 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-indigo-50);
      }
    }
  }
  .hover\:bg-indigo-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-indigo-200);
      }
    }
  }
  .hover\:bg-indigo-700 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-indigo-700);
      }
    }
  }
  .hover\:bg-indigo-800 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-indigo-800);
      }
    }
  }
  .hover\:bg-manifest-accent-light {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-accent-light);
      }
    }
  }
  .hover\:bg-manifest-bg {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-bg);
      }
    }
  }
  .hover\:bg-manifest-border {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-border);
      }
    }
  }
  .hover\:bg-manifest-card {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-card);
      }
    }
  }
  .hover\:bg-manifest-card\/20 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, #FFFFFF 20%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-manifest-card) 20%, transparent);
        }
      }
    }
  }
  .hover\:bg-manifest-danger {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-danger);
      }
    }
  }
  .hover\:bg-manifest-danger-light {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-danger-light);
      }
    }
  }
  .hover\:bg-manifest-danger-lighter {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-danger-lighter);
      }
    }
  }
  .hover\:bg-manifest-info-light {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-info-light);
      }
    }
  }
  .hover\:bg-manifest-primary-dark {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-primary-dark);
      }
    }
  }
  .hover\:bg-manifest-primary-light {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-primary-light);
      }
    }
  }
  .hover\:bg-manifest-success {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-success);
      }
    }
  }
  .hover\:bg-manifest-success-dark {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-success-dark);
      }
    }
  }
  .hover\:bg-manifest-success-light {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-success-light);
      }
    }
  }
  .hover\:bg-manifest-text {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-manifest-text);
      }
    }
  }
  .hover\:bg-purple-100 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-purple-100);
      }
    }
  }
  .hover\:bg-purple-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-purple-200);
      }
    }
  }
  .hover\:bg-red-50 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-red-50);
      }
    }
  }
  .hover\:bg-red-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-red-200);
      }
    }
  }
  .hover\:bg-red-700 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-red-700);
      }
    }
  }
  .hover\:bg-teal-50 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-teal-50);
      }
    }
  }
  .hover\:bg-yellow-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-yellow-200);
      }
    }
  }
  .hover\:from-emerald-100 {
    &:hover {
      @media (hover: hover) {
        --tw-gradient-from: var(--color-emerald-100);
        --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
      }
    }
  }
  .hover\:from-indigo-700 {
    &:hover {
      @media (hover: hover) {
        --tw-gradient-from: var(--color-indigo-700);
        --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
      }
    }
  }
  .hover\:to-purple-700 {
    &:hover {
      @media (hover: hover) {
        --tw-gradient-to: var(--color-purple-700);
        --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
      }
    }
  }
  .hover\:to-teal-100 {
    &:hover {
      @media (hover: hover) {
        --tw-gradient-to: var(--color-teal-100);
        --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
      }
    }
  }
  .hover\:text-amber-500 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-amber-500);
      }
    }
  }
  .hover\:text-amber-700 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-amber-700);
      }
    }
  }
  .hover\:text-green-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-green-600);
      }
    }
  }
  .hover\:text-indigo-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-indigo-600);
      }
    }
  }
  .hover\:text-manifest-primary {
    &:hover {
      @media (hover: hover) {
        color: var(--color-manifest-primary);
      }
    }
  }
  .hover\:text-manifest-primary-dark {
    &:hover {
      @media (hover: hover) {
        color: var(--color-manifest-primary-dark);
      }
    }
  }
  .hover\:text-manifest-text {
    &:hover {
      @media (hover: hover) {
        color: var(--color-manifest-text);
      }
    }
  }
  .hover\:text-manifest-text-muted {
    &:hover {
      @media (hover: hover) {
        color: var(--color-manifest-text-muted);
      }
    }
  }
  .hover\:text-manifest-text-muted\/70 {
    &:hover {
      @media (hover: hover) {
        color: color-mix(in srgb, #6B6560 70%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-manifest-text-muted) 70%, transparent);
        }
      }
    }
  }
  .hover\:text-red-300 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-red-300);
      }
    }
  }
  .hover\:text-red-500 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-red-500);
      }
    }
  }
  .hover\:text-red-700 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-red-700);
      }
    }
  }
  .hover\:text-red-800 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-red-800);
      }
    }
  }
  .hover\:text-teal-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-teal-600);
      }
    }
  }
  .hover\:text-white {
    &:hover {
      @media (hover: hover) {
        color: var(--color-white);
      }
    }
  }
  .hover\:underline {
    &:hover {
      @media (hover: hover) {
        text-decoration-line: underline;
      }
    }
  }
  .hover\:opacity-80 {
    &:hover {
      @media (hover: hover) {
        opacity: 80%;
      }
    }
  }
  .hover\:opacity-90 {
    &:hover {
      @media (hover: hover) {
        opacity: 90%;
      }
    }
  }
  .hover\:opacity-100 {
    &:hover {
      @media (hover: hover) {
        opacity: 100%;
      }
    }
  }
  .hover\:shadow {
    &:hover {
      @media (hover: hover) {
        --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
      }
    }
  }
  .hover\:shadow-lg {
    &:hover {
      @media (hover: hover) {
        --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
      }
    }
  }
  .hover\:shadow-md {
    &:hover {
      @media (hover: hover) {
        --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
      }
    }
  }
  .hover\:shadow-xl {
    &:hover {
      @media (hover: hover) {
        --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
      }
    }
  }
  .focus\:border-amber-500 {
    &:focus {
      border-color: var(--color-amber-500);
    }
  }
  .focus\:border-manifest-primary {
    &:focus {
      border-color: var(--color-manifest-primary);
    }
  }
  .focus\:border-red-500 {
    &:focus {
      border-color: var(--color-red-500);
    }
  }
  .focus\:border-transparent {
    &:focus {
      border-color: transparent;
    }
  }
  .focus\:bg-manifest-card {
    &:focus {
      background-color: var(--color-manifest-card);
    }
  }
  .focus\:ring-0 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-1 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-2 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-4 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-amber-100 {
    &:focus {
      --tw-ring-color: var(--color-amber-100);
    }
  }
  .focus\:ring-manifest-primary {
    &:focus {
      --tw-ring-color: var(--color-manifest-primary);
    }
  }
  .focus\:ring-manifest-primary-light {
    &:focus {
      --tw-ring-color: var(--color-manifest-primary-light);
    }
  }
  .focus\:ring-red-500 {
    &:focus {
      --tw-ring-color: var(--color-red-500);
    }
  }
  .focus\:ring-offset-0 {
    &:focus {
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-shadow: var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    }
  }
  .focus\:outline-none {
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
    }
  }
  .active\:scale-90 {
    &:active {
      --tw-scale-x: 90%;
      --tw-scale-y: 90%;
      --tw-scale-z: 90%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }
  }
  .active\:scale-95 {
    &:active {
      --tw-scale-x: 95%;
      --tw-scale-y: 95%;
      --tw-scale-z: 95%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }
  }
  .active\:scale-\[0\.9\] {
    &:active {
      scale: 0.9;
    }
  }
  .active\:scale-\[0\.92\] {
    &:active {
      scale: 0.92;
    }
  }
  .active\:scale-\[0\.95\] {
    &:active {
      scale: 0.95;
    }
  }
  .active\:scale-\[0\.96\] {
    &:active {
      scale: 0.96;
    }
  }
  .active\:scale-\[0\.97\] {
    &:active {
      scale: 0.97;
    }
  }
  .active\:scale-\[0\.98\] {
    &:active {
      scale: 0.98;
    }
  }
  .active\:bg-amber-200 {
    &:active {
      background-color: var(--color-amber-200);
    }
  }
  .active\:bg-black\/80 {
    &:active {
      background-color: color-mix(in srgb, #000 80%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-black) 80%, transparent);
      }
    }
  }
  .active\:bg-blue-700 {
    &:active {
      background-color: var(--color-blue-700);
    }
  }
  .active\:bg-green-100 {
    &:active {
      background-color: var(--color-green-100);
    }
  }
  .active\:bg-green-700 {
    &:active {
      background-color: var(--color-green-700);
    }
  }
  .active\:bg-indigo-900 {
    &:active {
      background-color: var(--color-indigo-900);
    }
  }
  .active\:bg-manifest-bg {
    &:active {
      background-color: var(--color-manifest-bg);
    }
  }
  .active\:bg-manifest-border {
    &:active {
      background-color: var(--color-manifest-border);
    }
  }
  .active\:bg-manifest-danger-lighter {
    &:active {
      background-color: var(--color-manifest-danger-lighter);
    }
  }
  .active\:bg-manifest-primary-light {
    &:active {
      background-color: var(--color-manifest-primary-light);
    }
  }
  .active\:bg-manifest-success-light {
    &:active {
      background-color: var(--color-manifest-success-light);
    }
  }
  .active\:bg-manifest-text {
    &:active {
      background-color: var(--color-manifest-text);
    }
  }
  .active\:opacity-70 {
    &:active {
      opacity: 70%;
    }
  }
  .active\:opacity-80 {
    &:active {
      opacity: 80%;
    }
  }
  .active\:opacity-90 {
    &:active {
      opacity: 90%;
    }
  }
  .disabled\:cursor-not-allowed {
    &:disabled {
      cursor: not-allowed;
    }
  }
  .disabled\:opacity-50 {
    &:disabled {
      opacity: 50%;
    }
  }
  .disabled\:opacity-70 {
    &:disabled {
      opacity: 70%;
    }
  }
  .motion-safe\:animate-spin {
    @media (prefers-reduced-motion: no-preference) {
      animation: var(--animate-spin);
    }
  }
  .sm\:col-span-2 {
    @media (width >= 40rem) {
      grid-column: span 2 / span 2;
    }
  }
  .sm\:mx-4 {
    @media (width >= 40rem) {
      margin-inline: calc(var(--spacing) * 4);
    }
  }
  .sm\:my-8 {
    @media (width >= 40rem) {
      margin-block: calc(var(--spacing) * 8);
    }
  }
  .sm\:mb-2 {
    @media (width >= 40rem) {
      margin-bottom: calc(var(--spacing) * 2);
    }
  }
  .sm\:mb-3 {
    @media (width >= 40rem) {
      margin-bottom: calc(var(--spacing) * 3);
    }
  }
  .sm\:mb-4 {
    @media (width >= 40rem) {
      margin-bottom: calc(var(--spacing) * 4);
    }
  }
  .sm\:mb-6 {
    @media (width >= 40rem) {
      margin-bottom: calc(var(--spacing) * 6);
    }
  }
  .sm\:block {
    @media (width >= 40rem) {
      display: block;
    }
  }
  .sm\:flex {
    @media (width >= 40rem) {
      display: flex;
    }
  }
  .sm\:hidden {
    @media (width >= 40rem) {
      display: none;
    }
  }
  .sm\:inline {
    @media (width >= 40rem) {
      display: inline;
    }
  }
  .sm\:inline-block {
    @media (width >= 40rem) {
      display: inline-block;
    }
  }
  .sm\:h-11 {
    @media (width >= 40rem) {
      height: calc(var(--spacing) * 11);
    }
  }
  .sm\:h-20 {
    @media (width >= 40rem) {
      height: calc(var(--spacing) * 20);
    }
  }
  .sm\:h-28 {
    @media (width >= 40rem) {
      height: calc(var(--spacing) * 28);
    }
  }
  .sm\:h-screen {
    @media (width >= 40rem) {
      height: 100vh;
    }
  }
  .sm\:max-h-\[85vh\] {
    @media (width >= 40rem) {
      max-height: 85vh;
    }
  }
  .sm\:w-20 {
    @media (width >= 40rem) {
      width: calc(var(--spacing) * 20);
    }
  }
  .sm\:w-28 {
    @media (width >= 40rem) {
      width: calc(var(--spacing) * 28);
    }
  }
  .sm\:w-96 {
    @media (width >= 40rem) {
      width: calc(var(--spacing) * 96);
    }
  }
  .sm\:w-auto {
    @media (width >= 40rem) {
      width: auto;
    }
  }
  .sm\:w-full {
    @media (width >= 40rem) {
      width: 100%;
    }
  }
  .sm\:max-w-96 {
    @media (width >= 40rem) {
      max-width: calc(var(--spacing) * 96);
    }
  }
  .sm\:max-w-lg {
    @media (width >= 40rem) {
      max-width: var(--container-lg);
    }
  }
  .sm\:max-w-md {
    @media (width >= 40rem) {
      max-width: var(--container-md);
    }
  }
  .sm\:max-w-sm {
    @media (width >= 40rem) {
      max-width: var(--container-sm);
    }
  }
  .sm\:translate-y-0 {
    @media (width >= 40rem) {
      --tw-translate-y: calc(var(--spacing) * 0);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
  .sm\:scale-95 {
    @media (width >= 40rem) {
      --tw-scale-x: 95%;
      --tw-scale-y: 95%;
      --tw-scale-z: 95%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }
  }
  .sm\:scale-100 {
    @media (width >= 40rem) {
      --tw-scale-x: 100%;
      --tw-scale-y: 100%;
      --tw-scale-z: 100%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }
  }
  .sm\:grid-cols-2 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .sm\:grid-cols-3 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .sm\:grid-cols-4 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .sm\:flex-row {
    @media (width >= 40rem) {
      flex-direction: row;
    }
  }
  .sm\:items-center {
    @media (width >= 40rem) {
      align-items: center;
    }
  }
  .sm\:items-start {
    @media (width >= 40rem) {
      align-items: flex-start;
    }
  }
  .sm\:justify-start {
    @media (width >= 40rem) {
      justify-content: flex-start;
    }
  }
  .sm\:gap-2 {
    @media (width >= 40rem) {
      gap: calc(var(--spacing) * 2);
    }
  }
  .sm\:rounded-2xl {
    @media (width >= 40rem) {
      border-radius: var(--radius-2xl);
    }
  }
  .sm\:p-0 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 0);
    }
  }
  .sm\:p-1 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 1);
    }
  }
  .sm\:p-4 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 4);
    }
  }
  .sm\:p-5 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 5);
    }
  }
  .sm\:p-8 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 8);
    }
  }
  .sm\:px-3 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 3);
    }
  }
  .sm\:px-4 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 4);
    }
  }
  .sm\:px-5 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 5);
    }
  }
  .sm\:px-6 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 6);
    }
  }
  .sm\:px-8 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 8);
    }
  }
  .sm\:py-1\.5 {
    @media (width >= 40rem) {
      padding-block: calc(var(--spacing) * 1.5);
    }
  }
  .sm\:py-2\.5 {
    @media (width >= 40rem) {
      padding-block: calc(var(--spacing) * 2.5);
    }
  }
  .sm\:py-8 {
    @media (width >= 40rem) {
      padding-block: calc(var(--spacing) * 8);
    }
  }
  .sm\:py-10 {
    @media (width >= 40rem) {
      padding-block: calc(var(--spacing) * 10);
    }
  }
  .sm\:pt-8 {
    @media (width >= 40rem) {
      padding-top: calc(var(--spacing) * 8);
    }
  }
  .sm\:align-middle {
    @media (width >= 40rem) {
      vertical-align: middle;
    }
  }
  .sm\:text-2xl {
    @media (width >= 40rem) {
      font-size: var(--text-2xl);
      line-height: var(--tw-leading, var(--text-2xl--line-height));
    }
  }
  .sm\:text-3xl {
    @media (width >= 40rem) {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
    }
  }
  .sm\:text-4xl {
    @media (width >= 40rem) {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }
  .sm\:text-5xl {
    @media (width >= 40rem) {
      font-size: var(--text-5xl);
      line-height: var(--tw-leading, var(--text-5xl--line-height));
    }
  }
  .sm\:text-6xl {
    @media (width >= 40rem) {
      font-size: var(--text-6xl);
      line-height: var(--tw-leading, var(--text-6xl--line-height));
    }
  }
  .sm\:text-base {
    @media (width >= 40rem) {
      font-size: var(--text-base);
      line-height: var(--tw-leading, var(--text-base--line-height));
    }
  }
  .sm\:text-lg {
    @media (width >= 40rem) {
      font-size: var(--text-lg);
      line-height: var(--tw-leading, var(--text-lg--line-height));
    }
  }
  .sm\:text-sm {
    @media (width >= 40rem) {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
    }
  }
  .sm\:text-manifest-text {
    @media (width >= 40rem) {
      color: var(--color-manifest-text);
    }
  }
  .md\:mx-auto {
    @media (width >= 48rem) {
      margin-inline: auto;
    }
  }
  .md\:my-16 {
    @media (width >= 48rem) {
      margin-block: calc(var(--spacing) * 16);
    }
  }
  .md\:mt-0 {
    @media (width >= 48rem) {
      margin-top: calc(var(--spacing) * 0);
    }
  }
  .md\:ml-\[60px\] {
    @media (width >= 48rem) {
      margin-left: 60px;
    }
  }
  .md\:ml-\[280px\] {
    @media (width >= 48rem) {
      margin-left: 280px;
    }
  }
  .md\:ml-\[var\(--sidebar-width\)\] {
    @media (width >= 48rem) {
      margin-left: var(--sidebar-width);
    }
  }
  .md\:flex {
    @media (width >= 48rem) {
      display: flex;
    }
  }
  .md\:hidden {
    @media (width >= 48rem) {
      display: none;
    }
  }
  .md\:h-16 {
    @media (width >= 48rem) {
      height: calc(var(--spacing) * 16);
    }
  }
  .md\:w-1\/3 {
    @media (width >= 48rem) {
      width: calc(1/3 * 100%);
    }
  }
  .md\:w-2\/3 {
    @media (width >= 48rem) {
      width: calc(2/3 * 100%);
    }
  }
  .md\:max-w-3xl {
    @media (width >= 48rem) {
      max-width: var(--container-3xl);
    }
  }
  .md\:max-w-xs {
    @media (width >= 48rem) {
      max-width: var(--container-xs);
    }
  }
  .md\:translate-x-0 {
    @media (width >= 48rem) {
      --tw-translate-x: calc(var(--spacing) * 0);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
  .md\:grid-cols-2 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-3 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .md\:flex-row {
    @media (width >= 48rem) {
      flex-direction: row;
    }
  }
  .md\:justify-start {
    @media (width >= 48rem) {
      justify-content: flex-start;
    }
  }
  .md\:gap-3 {
    @media (width >= 48rem) {
      gap: calc(var(--spacing) * 3);
    }
  }
  .md\:border-x {
    @media (width >= 48rem) {
      border-inline-style: var(--tw-border-style);
      border-inline-width: 1px;
    }
  }
  .md\:p-4 {
    @media (width >= 48rem) {
      padding: calc(var(--spacing) * 4);
    }
  }
  .md\:text-left {
    @media (width >= 48rem) {
      text-align: left;
    }
  }
  .md\:text-7xl {
    @media (width >= 48rem) {
      font-size: var(--text-7xl);
      line-height: var(--tw-leading, var(--text-7xl--line-height));
    }
  }
  .lg\:col-span-2 {
    @media (width >= 64rem) {
      grid-column: span 2 / span 2;
    }
  }
  .lg\:grid-cols-2 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-3 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-4 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .lg\:px-8 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 8);
    }
  }
  .\[\[data-theme\=dark\]_\&\]\:left-\[66\%\] {
    [data-theme=dark] & {
      left: 66%;
    }
  }
  .\[\[data-theme\=light\]_\&\]\:left-\[33\%\] {
    [data-theme=light] & {
      left: 33%;
    }
  }
}
#nprogress {
  pointer-events: none;
}
#nprogress .bar {
  background: #29d;
  position: fixed;
  z-index: 1031;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
}
#nprogress .peg {
  display: block;
  position: absolute;
  right: 0px;
  width: 100px;
  height: 100%;
  box-shadow: 0 0 10px #29d, 0 0 5px #29d;
  opacity: 1.0;
  -webkit-transform: rotate(3deg) translate(0px, -4px);
  -ms-transform: rotate(3deg) translate(0px, -4px);
  transform: rotate(3deg) translate(0px, -4px);
}
#nprogress .spinner {
  display: block;
  position: fixed;
  z-index: 1031;
  top: 15px;
  right: 15px;
}
#nprogress .spinner-icon {
  width: 18px;
  height: 18px;
  box-sizing: border-box;
  border: solid 2px transparent;
  border-top-color: #29d;
  border-left-color: #29d;
  border-radius: 50%;
  -webkit-animation: nprogress-spinner 400ms linear infinite;
  animation: nprogress-spinner 400ms linear infinite;
}
.nprogress-custom-parent {
  overflow: hidden;
  position: relative;
}
.nprogress-custom-parent #nprogress .spinner, .nprogress-custom-parent #nprogress .bar {
  position: absolute;
}
@-webkit-keyframes nprogress-spinner {
  0% {
    -webkit-transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
  }
}
@keyframes nprogress-spinner {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
:root {
  --manifest-primary: var(--color-manifest-primary);
  --manifest-primary-dark: var(--color-manifest-primary-dark);
  --manifest-primary-light: var(--color-manifest-primary-light);
  --manifest-primary-border: var(--color-manifest-primary-border);
  --manifest-secondary: var(--color-manifest-secondary);
  --manifest-secondary-light: var(--color-manifest-secondary-light);
  --manifest-accent: var(--color-manifest-accent);
  --manifest-accent-light: var(--color-manifest-accent-light);
  --manifest-text: var(--color-manifest-text);
  --manifest-text-muted: var(--color-manifest-text-muted);
  --manifest-border: var(--color-manifest-border);
  --manifest-border-strong: var(--color-manifest-border-strong);
  --manifest-bg: var(--color-manifest-bg);
  --manifest-card: var(--color-manifest-card);
  --manifest-success: var(--color-manifest-success);
  --manifest-success-dark: var(--color-manifest-success-dark);
  --manifest-success-light: var(--color-manifest-success-light);
  --manifest-warning: var(--color-manifest-warning);
  --manifest-warning-dark: var(--color-manifest-warning-dark);
  --manifest-warning-light: var(--color-manifest-warning-light);
  --manifest-danger: var(--color-manifest-danger);
  --manifest-danger-light: var(--color-manifest-danger-light);
  --manifest-danger-lighter: var(--color-manifest-danger-lighter);
  --manifest-danger-border: var(--color-manifest-danger-border);
  --manifest-info: var(--color-manifest-info);
  --manifest-info-light: var(--color-manifest-info-light);
  --manifest-cat-sale: var(--color-manifest-cat-sale);
  --manifest-cat-sale-bg: var(--color-manifest-cat-sale-bg);
  --manifest-cat-services: var(--color-manifest-cat-services);
  --manifest-cat-services-bg: var(--color-manifest-cat-services-bg);
  --manifest-cat-jobs: var(--color-manifest-cat-jobs);
  --manifest-cat-jobs-bg: var(--color-manifest-cat-jobs-bg);
  --manifest-cat-events: var(--color-manifest-cat-events);
  --manifest-cat-events-bg: var(--color-manifest-cat-events-bg);
  --manifest-cat-housing: var(--color-manifest-cat-housing);
  --manifest-cat-housing-bg: var(--color-manifest-cat-housing-bg);
  --manifest-cat-warning: var(--color-manifest-cat-warning);
  --manifest-cat-dark: var(--color-manifest-cat-dark);
  --manifest-bg-muted: var(--color-manifest-bg-muted);
  --manifest-text-light: var(--color-manifest-text-light);
  --sidebar-width: 280px;
  --sidebar-width-collapsed: 60px;
  --mobile-header-height: 3.5rem;
  --manifest-shadow-sm: 0 1px 2px rgba(45, 41, 38, 0.04);
  --manifest-shadow: 0 2px 8px rgba(45, 41, 38, 0.06), 0 1px 2px rgba(45, 41, 38, 0.04);
  --manifest-shadow-lg: 0 8px 24px rgba(45, 41, 38, 0.08), 0 2px 8px rgba(45, 41, 38, 0.04);
  --manifest-shadow-glow: 0 0 0 3px rgba(79, 70, 229, 0.15);
  --font-display: 'Fraunces', Georgia, serif;
  --font-body: 'DM Sans', system-ui, -apple-system, sans-serif;
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-section: 3rem;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --radius-full: 9999px;
  --transition-fast: 150ms ease;
  --transition-base: 200ms ease;
  --transition-slow: 300ms ease;
  --transition-spring: 300ms cubic-bezier(0.34, 1.56, 0.64, 1);
  --text-display-xl: 3.25rem;
  --text-display-lg: 2.5rem;
  --text-display: 2rem;
  --text-display-sm: 1.75rem;
  --text-h1: 1.5rem;
  --text-h2: 1.25rem;
  --text-h3: 1.125rem;
  --text-body: 0.9375rem;
  --text-sm: 0.875rem;
  --text-caption: 0.8125rem;
  --text-tiny: 0.6875rem;
  --text-overline: 0.6875rem;
  --text-micro: 0.625rem;
  --leading-display: 1.2;
  --leading-heading: 1.3;
  --leading-body: 1.6;
  --leading-tight: 1.4;
  --navbar-height: 64px;
  --navbar-offset: calc(var(--navbar-height) + env(safe-area-inset-top, 0px));
}
html, body {
  overscroll-behavior: none;
}
button, [role="button"], a, label, .manifest-btn, nav, .sidebar-item, .mobile-nav-item {
  -webkit-touch-callout: none;
  user-select: none;
  -webkit-user-select: none;
}
p, h1, h2, h3, h4, h5, h6, li, td, th, article, section, .phx-page-main p, .phx-page-main h1, .phx-page-main h2, .phx-page-main h3, .phx-page-main .post-body, .phx-page-main .prose {
  user-select: text;
  -webkit-user-select: text;
}
.hide-scrollbar {
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.hide-scrollbar::-webkit-scrollbar {
  display: none;
}
.category-pill-scroll {
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.category-pill-scroll::-webkit-scrollbar {
  display: none;
}
:root {
  --z-content: 10;
  --z-sidebar: 40;
  --z-overlay: 50;
  --z-modal: 60;
  --z-toast: 70;
}
.manifest-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-body);
  font-weight: 600;
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-md);
  transition: all 0.2s ease;
  border: none;
  cursor: pointer;
  min-height: 44px;
  touch-action: manipulation;
  text-decoration: none;
}
.manifest-btn-primary {
  background: var(--manifest-primary, #4F46E5);
  color: white;
  box-shadow: 0 2px 8px rgba(79, 70, 229, 0.15), 0 1px 2px rgba(79, 70, 229, 0.1), 0 2px 0 var(--manifest-primary-dark, #4338CA);
}
.manifest-btn-primary:hover {
  background: var(--manifest-primary-dark, #4338CA);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(79, 70, 229, 0.2), 0 2px 8px rgba(79, 70, 229, 0.1), 0 3px 0 var(--manifest-primary-dark, #4338CA);
}
.manifest-btn-primary:active {
  transform: translateY(1px);
  box-shadow: 0 1px 2px rgba(45, 41, 38, 0.04);
}
.manifest-btn-primary:disabled {
  background: var(--manifest-border, #E8E4E0);
  color: var(--manifest-text-muted, #8C857E);
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}
.manifest-btn-primary:disabled svg {
  color: var(--manifest-text-muted, #8C857E);
}
.manifest-btn-secondary {
  background: var(--manifest-card, #FFFFFF);
  color: var(--manifest-text, #2D2926);
  border: 1.5px solid var(--manifest-border, #E8E4E0);
  box-shadow: var(--manifest-shadow-sm, 0 1px 2px rgba(45, 41, 38, 0.04));
}
.manifest-btn-secondary:hover {
  background: var(--manifest-bg, #FDFCFB);
  border-color: var(--manifest-text-muted, #6B6560);
}
.manifest-btn-danger {
  background: var(--manifest-danger, #DC2626);
  color: white;
  box-shadow: 0 2px 8px rgba(220, 38, 38, 0.15);
}
.manifest-btn-danger:hover {
  background: var(--manifest-danger);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--manifest-danger) 85%, black);
  }
  transform: translateY(-1px);
}
.manifest-btn-danger:active {
  transform: translateY(1px);
}
.manifest-btn-ghost {
  background: transparent;
  color: var(--manifest-text-muted, #6B6560);
}
.manifest-btn-ghost:hover {
  background: var(--manifest-bg, #FDFCFB);
  color: var(--manifest-text, #2D2926);
}
.manifest-btn-sm {
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  min-height: 36px;
}
.manifest-btn-lg {
  padding: 1rem 2rem;
  font-size: 1.125rem;
  min-height: 52px;
}
.manifest-btn-full {
  width: 100%;
}
.manifest-nav-link {
  color: var(--manifest-text-muted);
  font-size: 0.9375rem;
  transition: color 0.15s;
}
.manifest-nav-link:hover {
  color: var(--manifest-primary);
}
.manifest-nav-cta {
  background: var(--manifest-primary);
  padding: 0.5rem 1.25rem;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(79, 70, 229, 0.2);
  transition: background 0.15s;
}
.manifest-nav-cta:hover {
  background: var(--manifest-primary-dark);
}
.manifest-lp {
  font-family: var(--font-body);
  background: var(--manifest-bg);
  color: var(--manifest-text);
}
.manifest-lp-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  background: rgba(253, 252, 251, 0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--manifest-border);
  padding-top: env(safe-area-inset-top, 0px);
}
.manifest-lp-logo {
  font-weight: 600;
  font-size: 1.125rem;
  letter-spacing: -0.02em;
  color: var(--manifest-primary);
}
.manifest-lp h1, .manifest-lp h2, .manifest-lp h3 {
  color: var(--manifest-text);
}
.manifest-lp p {
  color: var(--manifest-text-muted);
}
.manifest-lp-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.75rem;
  border-radius: var(--radius-full);
  font-size: 0.875rem;
  font-weight: 500;
  background: var(--manifest-primary-light);
  color: var(--manifest-primary);
  border: 1px solid var(--manifest-accent-light);
}
.manifest-lp-step {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
  padding: 1.5rem;
  border-radius: var(--radius-lg);
  background: var(--manifest-card);
  border: 1px solid var(--manifest-border);
}
.manifest-lp-step-number {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-weight: 600;
  font-size: 0.875rem;
  background: var(--manifest-cat-dark);
  color: white;
}
.manifest-lp-step-number.accent {
  background: var(--manifest-primary);
}
.manifest-lp-icon-box {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--manifest-primary-light);
}
@keyframes manifest-fade-up {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fade-up {
  animation: manifest-fade-up 0.5s ease-out forwards;
}
.fade-up-2 {
  animation: manifest-fade-up 0.5s 0.1s ease-out both;
}
.fade-up-3 {
  animation: manifest-fade-up 0.5s 0.2s ease-out both;
}
.fade-up-4 {
  animation: manifest-fade-up 0.5s 0.3s ease-out both;
}
@media (prefers-reduced-motion: reduce) {
  .fade-up, .fade-up-2, .fade-up-3, .fade-up-4 {
    animation: none;
    opacity: 1;
  }
}
.retry-btn {
  background: var(--manifest-card);
  color: var(--manifest-primary);
  border: 1.5px solid var(--manifest-primary);
  transition: all 0.2s ease;
}
.retry-btn:hover {
  background: var(--manifest-primary-light);
  border-color: var(--manifest-primary-dark);
  color: var(--manifest-primary-dark);
}
.dismiss-btn {
  background: transparent;
  color: var(--manifest-text-muted);
  border: none;
  transition: color 0.2s ease;
}
.dismiss-btn:hover {
  color: var(--manifest-text);
}
.signup-cta {
  background: var(--manifest-primary);
  color: white;
  border: none;
  box-shadow: 0 2px 8px rgba(79, 70, 229, 0.2);
  transition: all 0.2s ease;
  text-decoration: none;
}
.signup-cta:hover {
  background: var(--manifest-primary-dark);
  box-shadow: 0 4px 12px rgba(79, 70, 229, 0.3);
  transform: translateY(-1px);
}
.signup-card {
  background: var(--manifest-card);
  border: 1.5px solid var(--manifest-border);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.send-btn {
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
}
.send-btn:hover:not(:disabled) {
  transform: scale(1.05);
}
.send-btn:disabled {
  cursor: not-allowed;
}
.mani-avatar {
  background: var(--manifest-primary-light);
  border: 1px solid var(--manifest-accent-light);
}
.nav-cta-btn {
  transition: all 0.2s ease;
}
.nav-cta-btn:hover {
  background: var(--manifest-primary-dark) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(79, 70, 229, 0.25);
}
.nav-cta-btn:active {
  transform: translateY(0);
}
.btn-soft {
  background: var(--manifest-primary-light);
  color: var(--manifest-primary);
  border: 1px solid var(--manifest-accent-light);
}
.btn-soft:hover {
  background: var(--manifest-accent-light);
  color: var(--manifest-primary-dark);
}
[phx-page-loading] .phx-page-main {
  opacity: 0.6;
  transition: opacity 0.2s ease-out;
}
.phx-page-main {
  opacity: 1;
  transition: opacity 0.15s ease-in;
}
[phx-page-loading] #feed-loading-skeleton {
  display: block !important;
}
@keyframes manifest-stream-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
#feed-posts-stream > div {
  animation: manifest-stream-in 0.3s ease-out both;
}
#feed-posts-stream > div:nth-child(1) {
  animation-delay: 0s;
}
#feed-posts-stream > div:nth-child(2) {
  animation-delay: 0.04s;
}
#feed-posts-stream > div:nth-child(3) {
  animation-delay: 0.08s;
}
#feed-posts-stream > div:nth-child(4) {
  animation-delay: 0.12s;
}
#feed-posts-stream > div:nth-child(5) {
  animation-delay: 0.16s;
}
@keyframes manifest-skeleton-pulse {
  0%, 100% {
    opacity: 0.5;
  }
  50% {
    opacity: 1;
  }
}
.feed-skeleton-row {
  display: flex;
  gap: 0.75rem;
  padding: 1rem;
  background: var(--manifest-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--manifest-border);
  animation: manifest-skeleton-pulse 1.2s ease-in-out infinite;
}
.feed-skeleton-row .skeleton-circle {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: var(--manifest-border);
  flex-shrink: 0;
}
.feed-skeleton-row .skeleton-lines {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.feed-skeleton-row .skeleton-line {
  height: 0.75rem;
  border-radius: 4px;
  background: var(--manifest-border);
}
.feed-skeleton-row .skeleton-line:first-child {
  width: 40%;
}
.feed-skeleton-row .skeleton-line:nth-child(2) {
  width: 90%;
}
.feed-skeleton-row .skeleton-line:nth-child(3) {
  width: 65%;
}
@keyframes manifest-modal-backdrop-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes manifest-modal-backdrop-out {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes manifest-modal-content-in {
  from {
    opacity: 0;
    transform: translateY(24px) scale(0.96);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes manifest-modal-content-out {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  to {
    opacity: 0;
    transform: translateY(16px) scale(0.97);
  }
}
[role="dialog"] .fixed.inset-0.bg-manifest-text-muted, [role="dialog"] .fixed.inset-0[class*="bg-opacity"], .fixed.inset-0.z-50 > .flex > .fixed.inset-0[class*="bg-opacity"], .fixed.inset-0.z-50 > .flex > .fixed.inset-0.bg-manifest-text-muted {
  animation: manifest-modal-backdrop-in 0.2s ease-out both;
}
[role="dialog"] .inline-block, [role="dialog"] .transform, .fixed.inset-0.z-50 .inline-block.align-bottom {
  animation: manifest-modal-content-in 0.3s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.modal-enter {
  animation: manifest-modal-backdrop-in 0.2s ease-out both;
}
.modal-enter > div:not(.absolute) {
  animation: manifest-modal-content-in 0.3s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.modal-exit {
  animation: manifest-modal-backdrop-out 0.2s ease-in both;
}
.modal-exit > div:not(.absolute) {
  animation: manifest-modal-content-out 0.2s ease-in both;
}
#openStreetMap {
  opacity: 0;
  transition: opacity 0.4s ease-out;
}
#openStreetMap.map-loaded {
  opacity: 1;
}
#openStreetMap .map-loading-skeleton {
  opacity: 1;
  transition: opacity 0.3s ease-out;
}
#openStreetMap.map-loaded .map-loading-skeleton {
  opacity: 0;
  pointer-events: none;
}
.phx-click-loading {
  opacity: 0.65 !important;
  pointer-events: none;
  position: relative;
  transition: opacity 0.15s ease-out !important;
}
.phx-submit-loading {
  opacity: 0.65;
  pointer-events: none;
  transition: opacity 0.15s ease-out;
}
.phx-submit-loading button[type="submit"], .phx-submit-loading .manifest-btn {
  position: relative;
  color: transparent !important;
}
.phx-submit-loading button[type="submit"]::after, .phx-submit-loading .manifest-btn::after, .phx-click-loading.manifest-btn::after, button.phx-click-loading::after {
  content: "";
  position: absolute;
  width: 1rem;
  height: 1rem;
  top: 50%;
  left: 50%;
  margin-top: -0.5rem;
  margin-left: -0.5rem;
  border: 2px solid rgba(255, 255, 255, 0.8);
  border-right-color: transparent;
  border-radius: 50%;
  animation: manifest-btn-spin 0.6s linear infinite;
}
.phx-click-loading.manifest-btn, button.phx-click-loading {
  color: transparent !important;
}
@keyframes manifest-btn-spin {
  to {
    transform: rotate(360deg);
  }
}
.phx-change-loading {
  opacity: 0.7;
  transition: opacity 0.15s ease-out;
}
@keyframes manifest-chat-slide-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.chat-bubble-compact, .chat-bubble.mani-message, .chat-bubble {
  animation: manifest-chat-slide-in 0.25s ease-out both;
}
#mani-messages .prose-sm p {
  margin: 4px 0;
}
#mani-messages .prose-sm ul, #mani-messages .prose-sm ol {
  margin: 6px 0;
}
#mani-messages .prose-sm li {
  margin: 2px 0;
}
#mani-messages .prose-sm strong {
  font-weight: 600;
}
#mani-messages .prose-sm a {
  color: var(--manifest-primary);
  text-decoration: underline;
}
#mani-messages .prose-sm a:hover {
  color: var(--manifest-primary-dark);
}
.view-transition-container {
  position: relative;
}
.view-crossfade {
  animation: manifest-crossfade-in 0.25s ease-out both;
}
@keyframes manifest-crossfade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.list-view-container, .map-viewport {
  transition: opacity 0.2s ease-out;
}
* {
  -webkit-tap-highlight-color: transparent;
}
html {
  touch-action: manipulation;
}
button, a, [role="button"], .manifest-btn, input[type="submit"] {
  touch-action: manipulation;
  -webkit-user-select: none;
  user-select: none;
}
button:active, [role="button"]:active, .manifest-btn:active {
  transform: scale(0.97);
  transition: transform 0.1s ease-out;
}
.manifest-btn:active {
  transform: translateY(1px) scale(0.97);
}
.toast[role="alert"] {
  animation: manifest-toast-in 0.3s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.toast[role="alert"].removing {
  animation: manifest-toast-out 0.25s ease-in forwards;
}
@media (prefers-reduced-motion: reduce) {
  #feed-posts-stream > div, .chat-bubble-compact, .chat-bubble.mani-message, .chat-bubble, .view-crossfade, .toast[role="alert"], [role="dialog"] .inline-block, [role="dialog"] .transform, [role="dialog"] .fixed.inset-0, .fixed.inset-0.z-50 > .flex > .fixed.inset-0, .fixed.inset-0.z-50 .inline-block.align-bottom, .modal-enter, .modal-enter > div, .modal-exit, .modal-exit > div, .feed-skeleton-row, .phx-submit-loading button[type="submit"]::after, .phx-submit-loading .manifest-btn::after, .phx-click-loading.manifest-btn::after, button.phx-click-loading::after {
    animation: none !important;
  }
  .list-view-container, .map-viewport, #openStreetMap, .phx-page-main, .phx-click-loading, .phx-submit-loading, .phx-change-loading {
    transition: none !important;
  }
  button:active, [role="button"]:active, .manifest-btn:active {
    transform: none !important;
  }
}
.feature-card {
  background: var(--manifest-card);
  border: 1px solid var(--manifest-border);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  transition: box-shadow 0.15s, border-color 0.15s;
}
.feature-card:hover {
  box-shadow: var(--manifest-shadow);
  border-color: rgba(45, 41, 38, 0.12);
}
.post-card {
  background: var(--manifest-card);
  border: 1px solid var(--manifest-border);
  border-radius: var(--radius-lg);
  padding: 1rem;
  font-size: 0.875rem;
  transition: box-shadow 0.15s, border-color 0.15s, transform 0.15s;
}
.post-card:hover {
  box-shadow: var(--manifest-shadow);
  border-color: rgba(45, 41, 38, 0.12);
  transform: translateY(-1px);
}
.lp-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.125rem 0.5rem;
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 500;
}
.lp-divider {
  height: 1px;
  background: var(--manifest-border);
}
.manifest-card {
  background: var(--manifest-card);
  border: 1px solid var(--manifest-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--manifest-shadow);
}
.manifest-card:hover {
  box-shadow: var(--manifest-shadow-lg);
  border-color: rgba(45, 41, 38, 0.12);
}
.manifest-input {
  font-family: var(--font-body);
  font-size: 16px;
  padding: 0.875rem 1rem;
  border: 1.5px solid var(--manifest-border);
  border-radius: var(--radius-md);
  background: var(--manifest-card);
  color: var(--manifest-text);
  transition: all 0.2s ease;
  width: 100%;
  min-height: 44px;
}
.manifest-input::placeholder {
  color: var(--manifest-text-muted);
}
.manifest-input:focus {
  outline: none;
  border-color: var(--manifest-primary);
  box-shadow: var(--manifest-shadow-glow);
}
.manifest-input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.manifest-textarea {
  font-family: var(--font-body);
  font-size: 16px;
  padding: 0.875rem 1rem;
  border: 1.5px solid var(--manifest-border);
  border-radius: var(--radius-md);
  background: var(--manifest-card);
  color: var(--manifest-text);
  transition: all 0.2s ease;
  width: 100%;
  resize: vertical;
}
.manifest-textarea::placeholder {
  color: var(--manifest-text-muted);
}
.manifest-textarea:focus {
  outline: none;
  border-color: var(--manifest-primary);
  box-shadow: var(--manifest-shadow-glow);
}
.manifest-select {
  font-family: var(--font-body);
  font-size: 16px;
  padding: 0.875rem 1rem;
  border: 1.5px solid var(--manifest-border);
  border-radius: var(--radius-md);
  background: var(--manifest-card);
  color: var(--manifest-text);
  transition: all 0.2s ease;
  width: 100%;
  min-height: 44px;
  cursor: pointer;
}
.manifest-select:focus {
  outline: none;
  border-color: var(--manifest-primary);
  box-shadow: var(--manifest-shadow-glow);
}
.manifest-accent-dot {
  width: 8px;
  height: 8px;
  background: var(--manifest-primary);
  border-radius: 50%;
  display: inline-block;
}
.manifest-line-accent {
  position: relative;
}
.manifest-line-accent::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 32px;
  height: 3px;
  background: var(--manifest-primary);
  border-radius: 2px;
}
.list-view-container {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
}
.feed-scroll-container {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
  scroll-behavior: smooth;
}
@media (hover: none) and (pointer: coarse) {
  .list-view-container, .feed-scroll-container {
    scroll-snap-type: y proximity;
  }
  .list-view-container > div, .feed-scroll-container > div {
    scroll-snap-align: start;
  }
}
#create-post-page input, #create-post-page textarea, #create-post-page select {
  scroll-margin-bottom: 120px;
  scroll-padding-bottom: 120px;
}
@keyframes manifest-toast-in {
  0% {
    opacity: 0;
    transform: translateY(16px) scale(0.95);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes manifest-toast-out {
  0% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  100% {
    opacity: 0;
    transform: translateY(-8px) scale(0.95);
  }
}
.manifest-success-toast {
  animation: manifest-toast-in 0.3s ease-out forwards;
}
.manifest-success-toast.toast-exit {
  animation: manifest-toast-out 0.3s ease-in forwards;
}
.sf-marker-container {
  background: transparent !important;
  border: none !important;
}
.sf-marker {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid white;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
  cursor: pointer;
  transition: transform 0.2s;
}
.sf-marker:hover {
  transform: scale(1.2);
}
.sf-marker-normal {
  background: linear-gradient(135deg, var(--manifest-accent) 0%, var(--manifest-secondary) 100%);
}
.sf-marker-hot {
  background: linear-gradient(135deg, var(--manifest-cat-warning) 0%, var(--manifest-danger) 100%);
  position: relative;
}
.sf-marker-pulse {
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: rgba(249, 115, 22, 0.4);
  animation: sf-pulse 2s ease-in-out infinite;
}
@keyframes sf-pulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.6;
  }
  50% {
    transform: scale(1.5);
    opacity: 0;
  }
}
.safe-area-btn {
  left: max(1rem, env(safe-area-inset-left, 1rem)) !important;
  right: auto !important;
  bottom: max(5.5rem, calc(env(safe-area-inset-bottom, 0px) + 5.5rem)) !important;
}
@media (max-width: 640px) {
  .safe-area-btn {
    bottom: max(5rem, calc(env(safe-area-inset-bottom, 0px) + 5rem)) !important;
    left: 0.75rem !important;
  }
}
.map-viewport {
  position: fixed;
  top: var(--navbar-offset, 64px);
  left: 0;
  right: 0;
  bottom: 64px;
  width: 100vw;
  height: calc(100vh - var(--navbar-offset, 64px) - 64px);
  overflow: hidden;
  z-index: 10;
}
@media (min-width: 768px) {
  .map-viewport {
    left: 280px;
    top: 0;
    width: calc(100vw - 280px);
    height: 100vh;
    bottom: 0;
  }
  .safe-area-btn {
    left: calc(280px + 1rem) !important;
  }
  [data-sidebar-collapsed="true"] .map-viewport {
    left: 60px;
    width: calc(100vw - 60px);
  }
  [data-sidebar-collapsed="true"] .safe-area-btn {
    left: calc(60px + 1rem) !important;
  }
}
.map-viewport.hidden {
  display: none;
}
.map-container {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-color: var(--manifest-bg);
}
.map-loading-skeleton {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--manifest-bg);
  z-index: 5;
}
.map-loading-pulse {
  position: absolute;
  inset: 0;
  background: linear-gradient( 90deg, var(--manifest-bg) 0%, var(--manifest-card) 50%, var(--manifest-bg) 100% );
  background-size: 200% 100%;
  animation: mapPulse 1.5s ease-in-out infinite;
}
.map-loading-content {
  position: relative;
  z-index: 6;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@keyframes mapPulse {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}
#openStreetMap {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}
.map-container .leaflet-container {
  width: 100% !important;
  height: 100% !important;
}
.map-container .leaflet-map-pane, .map-container .leaflet-tile-pane {
  width: 100%;
  height: 100%;
}
.location-permission-message, .location-not-available {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 2rem;
  text-align: center;
  background-color: var(--manifest-bg);
  color: var(--manifest-text);
}
.permission-icon {
  font-size: 3rem;
  margin-bottom: 1rem;
}
.permission-title {
  font-size: 1.25rem;
  font-weight: bold;
  margin-bottom: 1rem;
  color: var(--manifest-text);
}
.permission-text {
  margin-bottom: 1.5rem;
  line-height: 1.6;
  color: var(--manifest-text-muted);
}
.permission-instructions {
  margin-bottom: 1.5rem;
}
.instructions-title {
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--manifest-text-muted);
}
.instructions-steps {
  font-size: 0.9rem;
  color: var(--manifest-text-muted);
}
.permission-retry-btn {
  background: linear-gradient(to right, var(--manifest-primary), var(--manifest-accent));
  color: white;
  border: none;
  padding: 0.75rem 1.5rem;
  border-radius: 0.5rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.3s ease;
}
.permission-retry-btn:hover {
  background: linear-gradient(to right, var(--manifest-primary-dark), var(--manifest-secondary));
}
.map-sidebar {
  width: 300px;
  height: 100%;
  background-color: var(--manifest-card);
  box-shadow: 0 0 10px rgba(0,0,0,0.2);
  overflow-y: auto;
  z-index: 1000;
  position: absolute;
  top: 0;
  left: 0;
}
.map-sidebar.hidden {
  display: none;
}
.map-sidebar-header {
  padding: 15px;
  border-bottom: 1px solid var(--manifest-border);
  display: flex;
  justify-content: space-between;
}
.map-sidebar-title {
  margin: 0;
  font-size: 16px;
}
.map-sidebar-close {
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  padding: 0;
}
.map-search-container {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 800px;
  margin: 10px auto;
  padding: 0 15px;
}
.map-search-box {
  background-color: var(--manifest-bg);
  padding: 12px 20px;
  margin: 0;
  box-shadow: none;
  font-size: 16px;
  border-radius: 12px;
  width: 100%;
  color: var(--manifest-text);
  border: 1px solid var(--manifest-border);
  transition: all 0.2s ease;
  outline: none;
}
.map-search-box:focus {
  background-color: var(--manifest-card);
  border-color: var(--manifest-primary);
}
.custom-marker {
  cursor: pointer !important;
  pointer-events: auto !important;
}
.custom-marker > div {
  cursor: pointer !important;
  pointer-events: auto !important;
}
.leaflet-marker-icon.custom-marker {
  cursor: pointer !important;
  pointer-events: auto !important;
  z-index: 1000 !important;
}
.map-marker-own {
  background-color: var(--manifest-primary);
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid var(--manifest-primary-dark);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: bold;
  font-size: 12px;
}
.map-marker-other {
  background-color: var(--manifest-danger);
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid var(--manifest-danger);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: bold;
  font-size: 12px;
}
.leaflet-container {
  background: var(--manifest-bg) !important;
  font-family: inherit !important;
  width: 100% !important;
  height: 100% !important;
  position: relative !important;
}
.leaflet-tile {
  border: 0 !important;
  outline: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block !important;
  max-width: none !important;
  image-rendering: auto !important;
  box-sizing: border-box !important;
}
.leaflet-tile-container {
  pointer-events: auto !important;
}
.leaflet-tile-loaded {
  opacity: 1 !important;
  visibility: visible !important;
}
.leaflet-fade-anim .leaflet-tile {
  transition: opacity 0.2s linear !important;
}
@layer base {
  html, body {
    font-family: var(--font-body);
    color: var(--manifest-text);
    background: var(--manifest-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
  }
  .manifest-display {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: var(--text-display);
    line-height: var(--leading-display);
    letter-spacing: -0.03em;
    font-optical-sizing: auto;
    color: var(--manifest-text);
  }
  .manifest-h1 {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: var(--text-h1);
    line-height: var(--leading-heading);
    letter-spacing: -0.02em;
    font-optical-sizing: auto;
    color: var(--manifest-text);
  }
  .manifest-h2 {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: var(--text-h2);
    line-height: var(--leading-heading);
    letter-spacing: -0.01em;
    color: var(--manifest-text);
  }
  .manifest-h3 {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: var(--text-h3);
    line-height: var(--leading-heading);
    color: var(--manifest-text);
  }
  .manifest-body {
    font-size: var(--text-body);
    line-height: var(--leading-body);
    color: var(--manifest-text);
  }
  .manifest-caption {
    font-size: var(--text-caption);
    line-height: var(--leading-tight);
    color: var(--manifest-text-muted);
  }
  .manifest-overline {
    font-size: var(--text-overline);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--manifest-text-muted);
  }
  .manifest-section {
    padding-top: var(--space-section);
    padding-bottom: var(--space-section);
  }
  .manifest-page-padding {
    padding: var(--space-xl) var(--space-lg);
  }
  html {
    scroll-behavior: smooth;
  }
  @media (prefers-reduced-motion: reduce) {
    html {
      scroll-behavior: auto;
    }
    *, *::before, *::after {
      animation-duration: 0.01ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.01ms !important;
    }
  }
}
.scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.scrollbar-hide::-webkit-scrollbar {
  display: none;
}
.manifest-page-enter {
  animation: manifest-page-fade-in 0.4s cubic-bezier(0.16, 1, 0.3, 1) both;
}
@keyframes manifest-page-fade-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.manifest-hover-lift {
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.manifest-hover-lift:hover {
  transform: translateY(-2px);
  box-shadow: var(--manifest-shadow-lg);
}
.manifest-focus-ring:focus, input:focus, textarea:focus, select:focus {
  outline: none;
  border-color: var(--manifest-primary) !important;
  box-shadow: var(--manifest-shadow-glow) !important;
}
.manifest-toggle {
  position: relative;
  width: 2.75rem;
  height: 1.5rem;
  border-radius: var(--radius-full);
  background-color: var(--manifest-border);
  transition: background-color var(--transition-base);
  cursor: pointer;
  flex-shrink: 0;
}
.manifest-toggle::after {
  content: '';
  position: absolute;
  top: 0.125rem;
  left: 0.125rem;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  background: white;
  box-shadow: 0 1px 3px rgba(0,0,0,0.15);
  transition: transform var(--transition-spring);
}
.manifest-toggle.active, .manifest-toggle:has(input:checked) {
  background-color: var(--manifest-primary);
}
.manifest-toggle.active::after, .manifest-toggle:has(input:checked)::after {
  transform: translateX(1.25rem);
}
@keyframes manifest-refined-pulse {
  0%, 100% {
    opacity: 0.4;
  }
  50% {
    opacity: 0.8;
  }
}
.manifest-skeleton {
  background: linear-gradient(90deg, var(--manifest-border) 25%, rgba(232, 228, 224, 0.6) 50%, var(--manifest-border) 75%);
  background-size: 200% 100%;
  animation: manifest-skeleton-shimmer 1.8s ease-in-out infinite;
  border-radius: var(--radius-sm);
}
@keyframes manifest-skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}
.manifest-touch-target {
  min-height: 44px;
  min-width: 44px;
}
.manifest-touch-target-lg {
  min-height: 48px;
  min-width: 48px;
}
.manifest-touch-target-xl {
  min-height: 52px;
}
.manifest-interactive {
  transition: all var(--transition-base);
  cursor: pointer;
}
.manifest-interactive:hover {
  background-color: rgba(79, 70, 229, 0.04);
}
.manifest-interactive:active {
  transform: scale(0.98);
}
.manifest-sticky-header {
  background: rgba(253, 252, 251, 0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--manifest-border);
}
.manifest-danger-hover:hover {
  background: var(--manifest-danger-light);
}
.sidebar-scroll {
  scrollbar-width: thin;
  scrollbar-color: var(--manifest-border) transparent;
}
.sidebar-scroll::-webkit-scrollbar {
  width: 4px;
}
.sidebar-scroll::-webkit-scrollbar-track {
  background: transparent;
}
.sidebar-scroll::-webkit-scrollbar-thumb {
  background: var(--manifest-border);
  border-radius: var(--radius-full);
}
.manifest-wordmark {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--manifest-text);
}
.manifest-nav-active-indicator {
  position: relative;
}
.manifest-nav-active-indicator::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 60%;
  border-radius: var(--radius-full);
  background: var(--manifest-primary);
  opacity: 0;
  transition: opacity var(--transition-base);
}
.manifest-nav-active-indicator.active::before {
  opacity: 1;
}
@keyframes manifest-msg-spring {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.chat-bubble-compact, .chat-bubble.mani-message, .chat-bubble {
  animation: manifest-msg-spring 0.3s var(--transition-spring) both;
}
.manifest-form-section {
  background: var(--manifest-card);
  border: 1px solid var(--manifest-border);
  border-radius: var(--radius-lg);
  padding: var(--space-md) var(--space-lg);
  box-shadow: var(--manifest-shadow-sm);
}
.manifest-form-section .manifest-overline, .manifest-section-header {
  font-size: var(--text-overline);
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--manifest-text);
  text-transform: uppercase;
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--manifest-border);
}
.manifest-form-section .manifest-input, .manifest-form-section .manifest-textarea {
  border-color: var(--manifest-border-strong);
  padding: var(--space-sm) var(--space-md);
  font-size: var(--text-body);
}
.manifest-form-section label {
  margin-bottom: var(--space-xs);
}
.manifest-options-collapsible {
  outline: none;
}
.manifest-options-collapsible:focus, .manifest-options-collapsible:focus-visible {
  outline: none;
}
.manifest-options-collapsible summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0;
  outline: none;
}
.manifest-options-collapsible summary:focus, .manifest-options-collapsible summary:focus-visible {
  outline: none;
}
.manifest-options-collapsible[open] > div {
  border-top: 1px solid var(--manifest-border, #E8E4E0);
  padding-top: 12px;
}
.manifest-options-collapsible summary::-webkit-details-marker {
  display: none;
}
.manifest-options-collapsible summary .manifest-chevron {
  transition: transform 0.2s ease;
}
.manifest-options-collapsible[open] summary .manifest-chevron {
  transform: rotate(180deg);
}
.manifest-bottom-nav {
  background: var(--manifest-card);
  border-top: 1px solid var(--manifest-border);
  padding-bottom: env(safe-area-inset-bottom, 0px);
}
.manifest-bottom-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1;
  gap: 2px;
  transition: color var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  min-height: 52px;
  color: var(--manifest-text-muted);
}
.manifest-bottom-nav-item.active {
  color: var(--manifest-primary);
}
.manifest-bottom-nav-item .nav-label {
  font-size: 10px;
  font-weight: 500;
}
.manifest-bottom-nav-item.active .nav-label {
  font-weight: 600;
}
.phx-page-main {
  opacity: 1;
  transition: opacity 0.2s ease-in;
}
[phx-page-loading] .phx-page-main {
  opacity: 0.5;
  transition: opacity 0.15s ease-out;
}
.will-change-transform {
  will-change: transform;
}
.will-change-opacity {
  will-change: opacity;
}
@media (hover: none) and (pointer: coarse) {
  button, a, [role="button"] {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }
  .manifest-btn, .manifest-card {
    transition-duration: 0.15s;
  }
  input, textarea, select {
    font-size: 16px !important;
  }
}
.manifest-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  overscroll-behavior: contain;
}
@media (min-width: 640px) {
  .manifest-modal-overlay {
    align-items: center;
    padding: 1rem;
  }
}
.manifest-modal-content {
  background: var(--manifest-card);
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  box-shadow: var(--manifest-shadow-lg);
  width: 100%;
  max-height: 90vh;
  max-height: 90svh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}
@media (min-width: 640px) {
  .manifest-modal-content {
    border-radius: var(--radius-xl);
    max-width: 28rem;
  }
}
.manifest-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-2xl) var(--space-lg);
  text-align: center;
}
.manifest-empty-state svg {
  width: 4rem;
  height: 4rem;
  color: var(--manifest-border);
  margin-bottom: var(--space-lg);
}
.manifest-empty-state h3 {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 1.125rem;
  color: var(--manifest-text);
  margin-bottom: var(--space-sm);
}
.manifest-empty-state p {
  font-size: 0.875rem;
  color: var(--manifest-text-muted);
  max-width: 20rem;
  line-height: 1.5;
}
.manifest-flash {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 500;
}
.manifest-flash-success {
  background: var(--manifest-success-light);
  color: var(--manifest-success);
  @supports (color: color-mix(in lab, red, red)) {
    color: color-mix(in srgb, var(--manifest-success) 60%, black);
  }
  border: 1px solid var(--manifest-success);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in srgb, var(--manifest-success) 30%, white);
  }
}
.manifest-flash-error {
  background: var(--manifest-danger-light);
  color: var(--manifest-danger);
  @supports (color: color-mix(in lab, red, red)) {
    color: color-mix(in srgb, var(--manifest-danger) 60%, black);
  }
  border: 1px solid var(--manifest-danger-border);
}
.manifest-flash-info {
  background: var(--manifest-info-light);
  color: var(--manifest-info);
  @supports (color: color-mix(in lab, red, red)) {
    color: color-mix(in srgb, var(--manifest-info) 60%, black);
  }
  border: 1px solid var(--manifest-info);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in srgb, var(--manifest-info) 30%, white);
  }
}
.manifest-flash-warning {
  background: var(--manifest-warning-light);
  color: var(--manifest-warning-dark);
  @supports (color: color-mix(in lab, red, red)) {
    color: color-mix(in srgb, var(--manifest-warning-dark) 60%, black);
  }
  border: 1px solid var(--manifest-warning);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in srgb, var(--manifest-warning) 30%, white);
  }
}
.manifest-touch-target {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  min-height: 44px;
}
.manifest-touch-target-sm {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}
.text-tiny {
  font-size: var(--text-tiny);
}
.text-micro {
  font-size: var(--text-micro);
}
.manifest-hero-heading {
  letter-spacing: -0.04em;
  line-height: 1.0;
}
.manifest-body-relaxed {
  line-height: 1.55;
}
.manifest-input-border-transparent {
  border: 1.5px solid transparent;
  line-height: 1.5;
}
.safe-area-top {
  padding-top: env(safe-area-inset-top, 0px);
}
.safe-area-bottom {
  padding-bottom: env(safe-area-inset-bottom, 0px);
}
.safe-area-inset-bottom {
  padding-bottom: max(1rem, env(safe-area-inset-bottom, 0px));
}
html, body {
  overflow-x: hidden;
  max-width: 100vw;
}
.manifest-label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--manifest-text);
  margin-bottom: 0.375rem;
}
.manifest-section {
  padding: var(--space-lg) 0;
}
.manifest-page-padding {
  padding-left: var(--space-md);
  padding-right: var(--space-md);
}
@media (min-width: 640px) {
  .manifest-page-padding {
    padding-left: var(--space-lg);
    padding-right: var(--space-lg);
  }
}
[phx-page-loading] {
  cursor: wait;
}
.modal-overlay, [role="dialog"] {
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}
.gpu-accelerated {
  transform: translateZ(0);
  backface-visibility: hidden;
}
.skeleton-loading {
  background: linear-gradient(90deg, var(--manifest-bg) 25%, var(--manifest-border) 50%, var(--manifest-bg) 75%);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.5s infinite;
}
@keyframes skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}
.fade-in {
  animation: fadeIn 0.3s ease-out;
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.manifest-page-enter {
  animation: manifestPageEnter var(--transition-slow) ease-out both;
}
@keyframes manifestPageEnter {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.manifest-sticky-header {
  background: rgba(253, 252, 251, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--manifest-border);
}
button, a, [role="button"], input[type="submit"], .manifest-touch {
  -webkit-tap-highlight-color: transparent;
}
button, [role="button"], input[type="submit"] {
  touch-action: manipulation;
}
.manifest-interactive {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: all var(--transition-base);
}
.manifest-interactive:active {
  transform: scale(0.97);
}
.manifest-touch-target {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  min-height: 44px;
}
.manifest-touch-target-lg {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  min-height: 48px;
}
.manifest-touch-target-xl {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  min-height: 52px;
}
.manifest-scroll {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}
.manifest-scroll-margin {
  scroll-margin-bottom: 120px;
}
.manifest-hover-lift {
  transition: box-shadow var(--transition-base), transform var(--transition-base), border-color var(--transition-base);
}
.manifest-hover-lift:hover {
  box-shadow: var(--manifest-shadow);
  transform: translateY(-1px);
}
.manifest-fab {
  position: fixed;
  z-index: 50;
  right: 16px;
  bottom: calc(140px + env(safe-area-inset-bottom, 0px));
  width: 56px;
  height: 56px;
  background: linear-gradient(135deg, var(--manifest-primary) 0%, var(--manifest-accent) 100%);
  border-radius: 50%;
  border: none;
  box-shadow: 0 4px 14px rgba(99, 102, 241, 0.4), 0 2px 6px rgba(0, 0, 0, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  -webkit-user-select: none;
  user-select: none;
  transition: transform 150ms ease, box-shadow 150ms ease;
}
.manifest-fab:hover {
  transform: scale(1.05);
  box-shadow: 0 6px 20px rgba(99, 102, 241, 0.5), 0 3px 8px rgba(0, 0, 0, 0.2);
}
.manifest-fab:active {
  transform: scale(0.95);
}
.manifest-fab svg {
  width: 26px;
  height: 26px;
  color: white;
  pointer-events: none;
}
html {
  line-height: 1.15;
  -moz-tab-size: 4;
  -o-tab-size: 4;
  tab-size: 4;
  -webkit-text-size-adjust: 100%;
}
body {
  margin: 0;
}
hr {
  color: inherit;
  height: 0;
}
abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
}
b, strong {
  font-weight: bolder;
}
code, kbd, pre, samp {
  font-family: ui-monospace,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;
  font-size: 1em;
}
small {
  font-size: 80%;
}
sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -.25em;
}
sup {
  top: -.5em;
}
table {
  border-color: inherit;
  text-indent: 0;
}
button, input, optgroup, select, textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}
button, select {
  text-transform: none;
}
[type=button], [type=reset], [type=submit], button {
  -webkit-appearance: button;
}
::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
legend {
  padding: 0;
}
progress {
  vertical-align: baseline;
}
::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
  height: auto;
}
::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}
summary {
  display: list-item;
}
blockquote, dd, dl, figure, h1, h2, h3, h4, h5, h6, hr, p, pre {
  margin: 0;
}
button {
  background-color: transparent;
  background-image: none;
}
fieldset, ol, ul {
  margin: 0;
  padding: 0;
}
ol, ul {
  list-style: none;
}
html {
  font-family: ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif,BlinkMacSystemFont,Helvetica Neue,Arial,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;
  line-height: 1.5;
}
body {
  font-family: inherit;
  line-height: inherit;
}
*, :after, :before {
  border: 0 solid;
  box-sizing: border-box;
}
hr {
  border-top-width: 1px;
}
img {
  border-style: solid;
}
textarea {
  resize: vertical;
}
input::-moz-placeholder, textarea::-moz-placeholder {
  color: var(--manifest-text-muted, #94a3b8);
  opacity: 1;
}
input::placeholder, textarea::placeholder {
  color: var(--manifest-text-muted, #94a3b8);
  opacity: 1;
}
[role=button], button {
  cursor: pointer;
}
table {
  border-collapse: collapse;
}
h1, h2, h3, h4, h5, h6 {
  font-size: inherit;
  font-weight: inherit;
}
a {
  color: inherit;
  text-decoration: inherit;
}
button, input, optgroup, select, textarea {
  color: inherit;
  line-height: inherit;
  padding: 0;
}
code, kbd, pre, samp {
  font-family: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;
}
audio, canvas, embed, iframe, img, object, svg, video {
  display: block;
  vertical-align: middle;
}
img, video {
  height: auto;
  max-width: 100%;
}
*, :after, :before {
  border-color: var(--manifest-border, #e2e8f0);
}
@media (min-width:640px) {
  .container {
    max-width: 640px;
  }
}
@media (min-width:768px) {
  .container {
    max-width: 768px;
  }
}
@media (min-width:1024px) {
  .container {
    max-width: 1024px;
  }
}
@media (min-width:1280px) {
  .container {
    max-width: 1280px;
  }
}
@media (min-width:1536px) {
  .container {
    max-width: 1536px;
  }
}
@media (max-width:640px) {
  .alert.items-center.justify-between.p-4 {
    margin: .5rem 0;
    padding: 1rem;
  }
}
.alert {
  line-height: 1.5;
}
@media (max-width:768px) {
  .alert.flex-col.h-full {
    height: calc(100vh - 64px);
    max-height: calc(100vh - 64px);
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
}
.alert {
  align-items: flex-start;
  border-color: currentColor;
  border-radius: .375rem;
  display: flex;
  font-size: .875rem;
  font-weight: 500;
  line-height: 1.25rem;
  overflow: hidden;
  padding: .7rem 1rem;
  position: relative;
  transition-duration: .15s;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
  vertical-align: middle;
}
.alert svg {
  flex: none;
  height: 1.25rem;
  margin-right: .75rem;
  width: 1.25rem;
}
.alert a {
  -webkit-text-decoration: underline;
  text-decoration: underline;
}
.prose .alert p {
  margin-bottom: 0;
  margin-top: 0;
}
.prose .alert a {
  color: inherit;
}
@media (max-width:640px) {
  .fixed.inset-0 .avatar {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  .fixed.inset-0 .avatar {
    align-items: center;
    padding: 1rem;
  }
}
@media (max-width:640px) {
  .avatar.items-center.justify-between.p-4, .flex.avatar.justify-between.p-4 {
    margin: .5rem 0;
    padding: 1rem;
  }
}
@media (max-width:768px) {
  .avatar.flex-col.h-full, .flex.flex-col.avatar {
    height: calc(100vh - 64px);
    max-height: calc(100vh - 64px);
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
}
.avatar {
  align-items: center;
  border-radius: 9999px;
  display: flex;
  flex-grow: 0;
  height: 3rem;
  height: 100%;
  justify-content: center;
  position: relative;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  width: 3rem;
  width: 100%;
  background-color: var(--manifest-secondary-light, #ede9fe);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5rem;
  text-align: center;
  text-transform: uppercase;
  color: var(--manifest-secondary, #6d28d9);
  max-height: 3rem;
  max-width: 3rem;
  min-height: 3rem;
  min-width: 3rem;
  -webkit-text-decoration: none;
  text-decoration: none;
}
@media (max-width:768px) {
  .flex.flex-col.avatar img, .flex.flex-col.prose .avatar img {
    height: calc(100vh - 64px);
    max-height: calc(100vh - 64px);
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
}
.avatar img, .prose .avatar img {
  border-radius: 9999px;
  height: 100%;
  margin-bottom: 0;
  margin-top: 0;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
}
.avatar svg {
  height: 1.5rem;
  width: 1.5rem;
}
@media (max-width:640px) {
  .fixed.inset-0 .badge, .fixed.inset-0 .prose a.badge {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  .fixed.inset-0 .badge, .fixed.inset-0 .prose a.badge {
    align-items: center;
    padding: 1rem;
  }
}
@media (max-width:640px) {
  .flex.badge.justify-between.p-4, .flex.prose a.badge.justify-between.p-4 {
    margin: .5rem 0;
    padding: 1rem;
  }
}
.badge, .prose a.badge {
  align-items: center;
  border-radius: 9999px;
  display: inline-flex;
  font-size: .75rem;
  font-weight: 600;
  line-height: 1.4;
  line-height: 1rem;
  line-height: 1;
  overflow: hidden;
  padding: .25rem .75rem;
  position: relative;
  text-align: center;
  -webkit-text-decoration: none;
  text-decoration: none;
  transition-duration: .15s;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
  vertical-align: baseline;
  white-space: nowrap;
  width: auto;
}
a.badge:focus {
  outline: 2px solid transparent;
  outline-offset: 2px;
  --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(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 transparent;
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 transparent);
}
.btn-primary, .prose a.btn-primary {
  background-color: var(--manifest-secondary, #6d28d9);
}
.btn-primary:hover, .prose a.btn-primary:hover {
  background-color: var(--manifest-primary-dark, #4c1d95);
}
.btn-primary, .prose a.btn-primary {
  color: var(--manifest-card, #fff);
}
@media (max-width:640px) {
  .card.items-center.justify-between.p-4, .prose a.card.items-center.justify-between.p-4 {
    margin: .5rem 0;
    padding: 1rem;
  }
}
@media (max-width:768px) {
  .card.flex-col.h-full, .flex.card.h-full, .flex.prose a.card.h-full, .prose a.card.flex-col.h-full {
    height: calc(100vh - 64px);
    max-height: calc(100vh - 64px);
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
}
.card, .prose a.card {
  border-radius: .25rem;
  border-width: 1px;
  display: flex;
  flex-direction: column;
  min-width: 0;
  position: relative;
  border-color: var(--manifest-border, #f1f5f9);
  background-color: var(--manifest-card, #fff);
  -webkit-text-decoration: none;
  text-decoration: none;
  transition-duration: .15s;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
a.card:focus, a.card:hover {
  --tw-shadow: 0 1px 2px 0 rgba(0,0,0,.05);
  box-shadow: 0 0 transparent,0 0 transparent,0 1px 2px 0 rgba(0,0,0,.05);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.prose a.card {
  font-weight: 400;
}
.card-body {
  flex: 1 1 auto;
  max-height: 100%;
  padding: .5rem .75rem;
}
.prose .card-body p {
  margin-bottom: 0;
  margin-top: 0;
}
.dialog.inset-0, .fixed.dialog {
  transform: translateZ(0);
}
@media (max-width:640px) {
  .dialog.inset-0 .max-w-lg, .fixed.dialog .max-w-lg {
    border-radius: 0;
    height: 100%;
    margin: 0;
    max-height: calc(100vh - 60px);
  }
  .dialog.inset-0 .overflow-y-auto, .fixed.dialog .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .dialog.inset-0 .items-center, .fixed.dialog .items-center {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  .dialog.inset-0 .max-w-lg, .fixed.dialog .max-w-lg {
    margin: 1rem;
    width: calc(100% - 2rem);
  }
  .dialog.inset-0 .items-center, .fixed.dialog .items-center {
    align-items: center;
    padding: 1rem;
  }
}
@media (max-width:640px) {
  .dialog.inset-0 .max-w-lg, .fixed.dialog .max-w-lg {
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    margin: 1rem;
    max-height: calc(90vh - env(safe-area-inset-bottom));
    overflow: hidden;
    width: calc(100% - 2rem);
  }
  .dialog.inset-0 .overflow-y-auto, .fixed.dialog .overflow-y-auto {
    overflow-y: auto;
  }
  .dialog.inset-0 .overflow-y-auto, .fixed.dialog .overflow-y-auto {
    flex: 1;
    height: auto;
    max-height: calc(100vh - 60px - env(safe-area-inset-bottom));
  }
  .dialog.inset-0 .overflow-y-auto, .fixed.dialog .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .dialog.inset-0 .items-end, .fixed.dialog .items-end {
    padding-bottom: env(safe-area-inset-bottom);
  }
}
@media (max-width:768px) {
  .dialog.inset-0, .fixed.dialog {
    bottom: 0;
    height: auto;
    left: 0;
    position: fixed;
    right: 0;
    top: 64px;
  }
  .flex.flex-col.dialog {
    height: calc(100vh - 64px);
    max-height: calc(100vh - 64px);
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
  .dialog {
    transform: translateZ(0);
  }
}
.dialog {
  bottom: 0;
  cursor: pointer;
  height: 100%;
  left: 0;
  overflow: hidden;
  position: fixed;
  right: 0;
  top: 0;
  width: 100%;
  z-index: 40;
  --tw-bg-opacity: 1;
  background-color: rgba(0,0,0,.5);
  background-color: rgba(0,0,0,var(--tw-bg-opacity));
  --tw-bg-opacity: 0.5;
  outline: 2px solid transparent;
  outline-offset: 2px;
  transition-duration: .15s;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.form-input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: .25rem;
  display: block;
  width: 100%;
  border: 1px solid var(--manifest-border, #e2e8f0);
  background-color: var(--manifest-card, #fff);
  font-size: .875rem;
  line-height: 1.5;
  padding: .5rem .75rem;
  color: var(--manifest-text, #0f172a);
}
.form-input::-moz-placeholder {
  color: var(--manifest-text-muted, #94a3b8);
}
.form-input::placeholder {
  color: var(--manifest-text-muted, #94a3b8);
}
.form-input {
  --tw-shadow: 0 0 transparent;
  box-shadow: 0 0 transparent,0 0 transparent,0 0 transparent;
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
  min-height: 39px;
  transition-duration: .15s;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.form-input:hover {
  border-color: var(--manifest-border-strong, #475569);
}
.form-input:focus {
  border-color: var(--manifest-primary, #6d28d9);
  outline: 2px solid transparent;
  outline-offset: 2px;
}
.form-input::-webkit-slider-runnable-track {
  border-color: transparent;
  border-radius: .25rem;
  cursor: pointer;
  height: .5rem;
  width: 100%;
  background-color: var(--manifest-bg-muted, #f1f5f9);
  color: transparent;
}
.form-input::-moz-range-track {
  border-color: transparent;
  border-radius: .25rem;
  cursor: pointer;
  height: .5rem;
  width: 100%;
  background-color: var(--manifest-bg-muted, #f1f5f9);
  color: transparent;
}
.form-input::-ms-track {
  border-color: transparent;
  border-radius: .25rem;
  cursor: pointer;
  height: .5rem;
  width: 100%;
  background-color: var(--manifest-bg-muted, #f1f5f9);
  color: transparent;
}
.form-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  border-radius: .25rem;
  border-style: none;
  height: 1.5rem;
  margin-top: -.5rem;
  width: 1rem;
  background-color: var(--manifest-secondary, #6d28d9);
}
.form-input::-moz-range-thumb {
  -moz-appearance: none;
  appearance: none;
  border-radius: .25rem;
  border-style: none;
  height: 1.5rem;
  margin-top: -.5rem;
  width: 1rem;
  background-color: var(--manifest-secondary, #6d28d9);
}
.form-input::-ms-thumb {
  appearance: none;
  border-radius: .25rem;
  border-style: none;
  height: 1.5rem;
  margin-top: -.5rem;
  width: 1rem;
  background-color: var(--manifest-secondary, #6d28d9);
}
.form-input::-moz-focus-outer {
  border-width: 0;
}
.form-input::-ms-fill-lower, .form-input::-ms-fill-upper {
  border-radius: .25rem;
  background-color: var(--manifest-border, #e2e8f0);
}
.form-input::-ms-fill-upper {
  margin-right: .75rem;
}
.form-input:disabled {
  cursor: not-allowed;
  border-color: var(--manifest-border-strong, #cbd5e1);
  background-color: var(--manifest-border-strong, #cbd5e1);
  opacity: 1;
}
.form-input[readonly] {
  cursor: default;
  border-color: var(--manifest-bg-muted, #f1f5f9);
  background-color: var(--manifest-bg-muted, #f1f5f9);
  opacity: 1;
}
.progress {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-radius: 9999px;
  border-width: 0;
  display: block;
  height: .75rem;
  overflow: hidden;
  padding: 0;
  width: 100%;
}
.progress::-webkit-progress-bar {
  background-color: var(--manifest-bg-muted, #f1f5f9);
}
.progress::-webkit-progress-value {
  background-color: currentColor;
}
.progress::-moz-progress-bar {
  background-color: currentColor;
}
.progress::-ms-fill {
  background-color: currentColor;
  border-width: 0;
}
.progress:indeterminate {
  animation: pulse 2s cubic-bezier(.4,0,.6,1) infinite;
  background-image: linear-gradient(90deg,var(--manifest-border, #e2e8f0),currentColor,var(--manifest-border, #e2e8f0));
}
.progress:indeterminate::-moz-progress-bar {
  background-color: transparent;
}
.progress:indeterminate::-webkit-progress-bar {
  background-color: transparent;
}
.toast {
  border-radius: .375rem;
  flex-basis: 24rem;
  font-size: .875rem;
  max-width: 24rem;
  overflow: hidden;
  padding: .7rem .7rem .7rem .9rem;
  z-index: 50;
}
.fixed.inset-0 {
  transform: translateZ(0);
}
@media (max-width:640px) {
  .fixed.inset-0 .max-w-lg {
    border-radius: 0;
    height: 100%;
    margin: 0;
    max-height: calc(100vh - 60px);
  }
  .fixed.inset-0 .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .fixed.inset-0 .items-center {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  .fixed.inset-0 .max-w-lg {
    margin: 1rem;
    width: calc(100% - 2rem);
  }
  .fixed.inset-0 .items-center {
    align-items: center !important;
    padding: 1rem;
  }
}
.badge {
  align-items: center;
  border-radius: 9999px;
  display: inline-flex;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .05em;
  padding: .25rem .75rem;
  text-transform: uppercase;
}
.badge.primary {
  background: var(--manifest-accent-light, #e0e7ff);
  color: var(--manifest-secondary, #5b21b6);
}
.badge.success {
  background: var(--manifest-success-light, #d1fae5);
  color: var(--manifest-success-dark, #065f46);
}
.badge.warning {
  background: var(--manifest-warning-light, #fef3c7);
  color: var(--manifest-warning-dark, #92400e);
}
.badge.error {
  background: var(--manifest-danger-light, #fee2e2);
  color: var(--manifest-danger, #991b1b);
}
.avatar {
  border: 2px solid var(--manifest-card, #fff);
  border-radius: 50%;
  box-shadow: var(--manifest-shadow-sm, 0 2px 4px rgba(0,0,0,.1));
  -o-object-fit: cover;
  object-fit: cover;
}
.avatar.sm {
  height: 2rem;
  width: 2rem;
}
.avatar.md {
  height: 3rem;
  width: 3rem;
}
.avatar.lg {
  height: 4rem;
  width: 4rem;
}
.avatar.xl {
  height: 6rem;
  width: 6rem;
}
.skeleton {
  animation: skeleton-shimmer 1.5s infinite;
  border-radius: 8px;
}
.loading-dots {
  display: inline-flex;
  gap: .25rem;
}
.loading-dots span {
  animation: loading-dot 1.4s ease-in-out infinite;
  background: var(--manifest-accent, #6366f1);
  border-radius: 50%;
  height: .5rem;
  width: .5rem;
}
.loading-dots span:first-child {
  animation-delay: -.32s;
}
.loading-dots span:nth-child(2) {
  animation-delay: -.16s;
}
@keyframes loading-dot {
  0%, 80%, to {
    transform: scale(0);
  }
  40% {
    transform: scale(1);
  }
}
.fade-in {
  animation: fade-in .5s ease-out;
}
.slide-up {
  animation: slide-up .5s ease-out;
}
.scale-in {
  animation: scale-in .3s ease-out;
}
@keyframes fade-in {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes slide-up {
  0% {
    opacity: 0;
    transform: translateY(1rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes scale-in {
  0% {
    opacity: 0;
    transform: scale(.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
.focus-ring:focus {
  box-shadow: 0 0 0 3px rgba(99,102,241,.2);
  outline: none;
}
.divider {
  background: var(--manifest-border, #e2e8f0);
  height: 1px;
  margin: 1.5rem 0;
}
.divider.thick {
  height: 2px;
}
.divider.dashed {
  background: none;
  border-top: 1px dashed var(--manifest-border, #e2e8f0);
}
@media (max-width:640px) {
  a[href], button {
    align-items: center;
    display: flex;
    justify-content: center;
    min-height: 48px;
    padding: .875rem;
    touch-action: manipulation;
  }
}
@media screen and (-webkit-min-device-pixel-ratio:0) {
  input, select, textarea {
    font-size: 16px !important;
  }
}
form[phx-submit] input[type=email], form[phx-submit] input[type=password], form[phx-submit] input[type=text] {
  background-color: var(--manifest-card, #fff);
  border: 2px solid var(--manifest-border, #e5e7eb);
  border-radius: 8px;
  transition: border-color .2s ease;
}
form[phx-submit] input:focus {
  border-color: var(--manifest-accent, #6366f1);
  box-shadow: 0 0 0 3px rgba(99,102,241,.1);
  outline: none;
}
.form-input:focus {
  border-color: var(--manifest-primary, #4f46e5);
  box-shadow: var(--manifest-shadow-glow, 0 0 0 3px rgba(79,70,229,.1));
  outline: none;
}
.button:active {
  transform: scale(.98);
}
.toggle-bg {
  position: relative;
  transition: background-color .2s ease-in-out;
}
.toggle-dot {
  transform: translateX(0);
  transition: transform .2s ease-in-out;
}
nav.inset-0 {
  transform: translateZ(0);
}
@media (max-width:640px) {
  nav.inset-0 .max-w-lg {
    border-radius: 0;
    height: 100%;
    margin: 0;
    max-height: calc(100vh - 60px);
  }
  nav.inset-0 .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  nav.inset-0 .items-center {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  nav.inset-0 .max-w-lg {
    margin: 1rem;
    width: calc(100% - 2rem);
  }
  nav.inset-0 .items-center {
    align-items: center;
    padding: 1rem;
  }
}
@media (max-width:640px) {
  nav.inset-0 .max-w-lg {
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    margin: 1rem;
    max-height: calc(90vh - env(safe-area-inset-bottom));
    overflow: hidden;
    width: calc(100% - 2rem);
  }
  nav.inset-0 .overflow-y-auto {
    flex: 1;
    height: auto;
    max-height: calc(100vh - 60px - env(safe-area-inset-bottom));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  nav.inset-0 .items-end {
    padding-bottom: env(safe-area-inset-bottom);
  }
}
@media (max-width:768px) {
  nav.inset-0 {
    bottom: 0;
    height: auto;
    left: 0;
    position: fixed;
    right: 0;
    top: 64px;
  }
  nav {
    transform: translateZ(0);
  }
}
nav {
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: hsla(0,0%,100%,.8);
  border-bottom: 1px solid hsla(0,0%,100%,.2);
  box-shadow: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06),0 1px 0 hsla(0,0%,100%,.1);
  box-shadow: var(--shadow-sm),0 1px 0 hsla(0,0%,100%,.1);
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  transition: all .3s cubic-bezier(.4,0,.2,1);
  transition: var(--transition);
  z-index: 50;
}
nav:hover {
  background: hsla(0,0%,100%,.9);
  box-shadow: 0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
nav .button.small.primary {
  background: linear-gradient(135deg,var(--manifest-accent, #6366f1),var(--manifest-primary, #4f46e5));
  border: none;
  border-radius: var(--border-radius-lg, 1rem);
  box-shadow: var(--manifest-shadow-sm);
}
nav .button.small.primary:hover {
  background: linear-gradient(135deg,var(--manifest-accent-light, #818cf8),var(--manifest-accent, #6366f1));
  box-shadow: var(--manifest-shadow);
  transform: translateY(-1px);
}
main {
  min-height: 100vh;
  padding-top: 4rem;
  position: relative;
}
main>* {
  animation: fadeInUp .6s cubic-bezier(.4,0,.2,1);
}
@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
label:hover .toggle-bg {
  background-color: var(--manifest-border, #e5e7eb);
}
label:hover .toggle-bg.bg-indigo-500 {
  background-color: var(--manifest-primary-dark, #4338ca);
}
label:hover .toggle-dot {
  box-shadow: 0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
}
label:active .toggle-dot {
  transform: scale(.95);
}
#settings-form {
  transition: all .3s ease;
}
#settings-form input:not([type=checkbox]), #settings-form textarea {
  transition: border-color .2s ease;
}
#settings-form input:not([type=checkbox]):hover, #settings-form textarea:hover {
  border-color: var(--manifest-accent, #6366f1);
}
#settings-form .invalid-feedback {
  font-size: .875rem;
  line-height: 1.25rem;
  margin-top: .25rem;
  color: var(--manifest-danger, #dc2626);
}
input[type=file]::file-selector-button {
  border-radius: 9999px;
  border-width: 0;
  cursor: pointer;
  line-height: 1.5;
  margin-right: 1rem;
  background-color: var(--manifest-primary-light, #eef2ff);
}
input[type=file]::file-selector-button:hover {
  background-color: var(--manifest-accent-light, #e0e7ff);
}
input[type=file]::file-selector-button {
  font-size: .875rem;
  font-weight: 600;
  line-height: 1.25rem;
  padding: .5rem 1rem;
  color: var(--manifest-primary-dark, #4338ca);
  transition-duration: .15s;
  transition-property: background-color,border-color,color,fill,stroke;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
input[type=checkbox] {
  border-radius: .25rem;
  border-color: var(--manifest-border-strong, #cbd5e1);
}
input[type=checkbox]:focus {
  border-color: var(--manifest-primary-border, #a5b4fc);
}
input[type=checkbox] {
  color: var(--manifest-primary, #4f46e5);
  --tw-shadow: 0 1px 2px 0 rgba(0,0,0,.05);
  box-shadow: 0 0 transparent,0 0 transparent,0 1px 2px 0 rgba(0,0,0,.05);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
input[type=checkbox]: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(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 transparent;
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 transparent);
  --tw-ring-opacity: 1;
  --tw-ring-color: rgba(199,210,254,var(--tw-ring-opacity));
  --tw-ring-offset-width: 0px;
}
input[type=checkbox] {
  cursor: pointer;
  min-height: 1.25rem;
  min-width: 1.25rem;
  -webkit-tap-highlight-color: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #fff;
  position: relative;
}
input[type=checkbox]:checked {
  background-color: var(--manifest-primary, #4f46e5);
  border-color: var(--manifest-primary, #4f46e5);
}
input[type=checkbox]:checked:after {
  border: solid #fff;
  border-width: 0 2px 2px 0;
  content: "";
  height: 10px;
  left: 5px;
  position: absolute;
  top: 2px;
  transform: rotate(45deg);
  width: 6px;
}
@media (max-width:640px) {
  input[type=checkbox] {
    margin: .5rem;
    transform: scale(1.2);
  }
  input[type=checkbox]+label {
    display: inline-block;
    padding: .5rem;
  }
  .flex.items-center.justify-between.p-4 {
    margin: .5rem 0;
    padding: 1rem;
  }
}
:root {
  --primary: var(--manifest-accent, #6366f1);
  --primary-dark: var(--manifest-primary, #4f46e5);
  --primary-light: var(--manifest-accent-light, #818cf8);
  --primary-50: var(--manifest-primary-light, #eef2ff);
  --primary-100: var(--manifest-accent-light, #e0e7ff);
  --primary-500: var(--manifest-accent, #6366f1);
  --primary-600: var(--manifest-secondary, #5b21b6);
  --primary-900: #312e81;
  --accent: #ec4899;
  --accent-light: #f472b6;
  --accent-dark: #db2777;
  --success: var(--manifest-success, #059669);
  --success-light: #34d399;
  --warning: var(--manifest-warning, #f59e0b);
  --error: var(--manifest-danger, #dc2626);
  --error-light: #f87171;
  --background: var(--manifest-card, #fff);
  --surface: var(--manifest-bg, #f8fafc);
  --surface-elevated: var(--manifest-card, #fff);
  --border: var(--manifest-border, #e2e8f0);
  --border-light: var(--manifest-bg-muted, #f1f5f9);
  --divider: var(--manifest-border, #e2e8f0);
  --text-primary: var(--manifest-text, #111827);
  --text-secondary: #374151;
  --text-tertiary: var(--manifest-text-muted, #6b7280);
  --text-quaternary: #9ca3af;
  --gradient-primary: linear-gradient(135deg,var(--manifest-accent) 0%,var(--manifest-primary) 100%);
  --gradient-accent: linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);
  --gradient-background: linear-gradient(135deg,var(--manifest-accent, #667eea),var(--manifest-secondary, #764ba2));
  --hover-lift: translateY(-2px);
  --active-scale: scale(0.98);
  --focus-ring: 0 0 0 4px rgba(79,70,229,.2);
  --glass-background: hsla(0,0%,100%,.9);
  --glass-border: hsla(0,0%,100%,.3);
  --glass-blur: blur(20px);
  --neutral-50: #f9fafb;
  --neutral-100: #f3f4f6;
  --neutral-200: #e5e7eb;
  --neutral-300: #d1d5db;
  --neutral-400: #9ca3af;
  --neutral-500: #6b7280;
  --neutral-600: #4b5563;
  --neutral-700: #374151;
  --neutral-800: #1f2937;
  --neutral-900: #111827;
  --shadow-xs: 0 1px 2px rgba(0,0,0,.05);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  --shadow-md: 0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);
  --shadow-lg: 0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05);
  --shadow-xl: 0 20px 25px rgba(0,0,0,.1),0 10px 10px rgba(0,0,0,.04);
  --transition-fast: all 0.15s cubic-bezier(0.4,0,0.2,1);
  --transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  --transition-slow: all 0.5s cubic-bezier(0.4,0,0.2,1);
  --border-radius-sm: 0.375rem;
  --border-radius: 0.5rem;
  --border-radius-md: 0.75rem;
  --border-radius-lg: 1rem;
  --border-radius-xl: 1.25rem;
  --spacing-xs: 0.25rem;
  --spacing-sm: 0.5rem;
  --spacing-md: 1rem;
  --spacing-lg: 1.5rem;
  --spacing-xl: 2rem;
}
body {
  background: linear-gradient(135deg,#f8fafc,#e2e8f0);
  background-attachment: fixed;
  font-feature-settings: "cv02","cv03","cv04","cv11";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;
  line-height: 1.6;
}
body, h1, h2, h3, h4, h5, h6 {
  color: #111827;
  color: var(--text-primary);
}
h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  letter-spacing: -.025em;
  line-height: 1.2;
  margin-bottom: .5em;
}
h1 {
  font-size: max(1.875rem,min(4vw,3rem));
  font-weight: 800;
  letter-spacing: -.05em;
}
h2 {
  font-size: max(1.5rem,min(3vw,2.25rem));
  font-weight: 700;
}
h3 {
  font-size: max(1.25rem,min(2.5vw,1.875rem));
  font-weight: 600;
}
p {
  color: #374151;
  color: var(--text-secondary);
  font-size: 1rem;
  line-height: 1.7;
  margin-bottom: 1rem;
}
.text-sm {
  line-height: 1.5;
}
.text-xs {
  line-height: 1.4;
}
body:before {
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: hsla(0,0%,100%,.8);
  bottom: 0;
  content: "";
  left: 0;
  pointer-events: none;
  position: fixed;
  right: 0;
  top: 0;
  z-index: -1;
}
.button {
  align-items: center;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  display: inline-flex;
  font-family: inherit;
  font-weight: 600;
  gap: .5rem;
  justify-content: center;
  letter-spacing: .025em;
  overflow: hidden;
  position: relative;
  -webkit-text-decoration: none;
  text-decoration: none;
  transition: all .2s cubic-bezier(.4,0,.2,1);
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
  box-shadow: 0 1px 2px rgba(0,0,0,.05),inset 0 0 0 1px hsla(0,0%,100%,.05);
  min-height: 44px;
  touch-action: manipulation;
}
.button:before {
  background: linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);
  content: "";
  height: 100%;
  left: -100%;
  position: absolute;
  top: 0;
  transition: left .5s;
  width: 100%;
}
.button:hover:before {
  left: 100%;
}
.button:hover {
  box-shadow: 0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05);
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}
.button:active {
  box-shadow: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
  transform: translateY(0);
}
.button.primary {
  background: linear-gradient(135deg,#6366f1,#5b21b6);
  background: linear-gradient(135deg,var(--primary) 0,var(--primary-600) 100%);
  box-shadow: 0 4px 8px rgba(99,102,241,.25),inset 0 0 0 1px hsla(0,0%,100%,.1);
}
.button.primary:hover {
  background: linear-gradient(135deg,#818cf8,#6366f1);
  background: linear-gradient(135deg,var(--primary-light) 0,var(--primary) 100%);
  box-shadow: 0 6px 16px rgba(99,102,241,.35),inset 0 0 0 1px hsla(0,0%,100%,.2);
  transform: translateY(-1px);
}
.button.primary:active {
  box-shadow: 0 2px 4px rgba(99,102,241,.25),inset 0 0 0 1px hsla(0,0%,100%,.1);
  transform: translateY(0);
}
.button.secondary {
  background: #fff;
  border: 1px solid #e2e8f0;
  border: 1px solid var(--border);
  box-shadow: 0 1px 2px rgba(0,0,0,.05),inset 0 0 0 1px hsla(0,0%,100%,.05);
  color: #6366f1;
  color: var(--primary);
}
.button.secondary:hover {
  background: #eef2ff;
  background: var(--primary-50);
  border-color: #818cf8;
  border-color: var(--primary-light);
  box-shadow: 0 4px 8px rgba(0,0,0,.1),inset 0 0 0 1px hsla(0,0%,100%,.1);
  transform: translateY(-1px);
}
.button.ghost {
  background: transparent;
  border: none;
  box-shadow: none;
  color: #6366f1;
  color: var(--primary);
}
.button.ghost:hover {
  background: #eef2ff;
  background: var(--primary-50);
  color: #5b21b6;
  color: var(--primary-600);
}
.button.outline {
  background: transparent;
  border: 2px solid #6366f1;
  border: 2px solid var(--primary);
  color: #6366f1;
  color: var(--primary);
}
.button.outline:hover {
  background: var(--manifest-accent, #6366f1);
  color: #fff;
}
.button.secondary {
  background: linear-gradient(135deg,#ec4899,#db2777);
  background: linear-gradient(135deg,var(--accent) 0,var(--accent-dark) 100%);
  border-color: #ec4899;
  border-color: var(--accent);
}
.button.secondary:hover {
  background: linear-gradient(135deg,#f472b6,#ec4899);
  background: linear-gradient(135deg,var(--accent-light) 0,var(--accent) 100%);
  box-shadow: 0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05),0 0 20px rgba(236,72,153,.3);
  box-shadow: var(--shadow-lg),0 0 20px rgba(236,72,153,.3);
}
.card {
  background: #fff;
  background: var(--surface-elevated);
  border: 1px solid #f1f5f9;
  border: 1px solid var(--border-light);
  border-radius: 16px;
  box-shadow: 0 1px 3px rgba(0,0,0,.05),0 1px 2px rgba(0,0,0,.1);
  overflow: hidden;
  position: relative;
  transition: all .3s cubic-bezier(.4,0,.2,1);
}
.card:hover {
  border-color: #818cf8;
  border-color: var(--primary-light);
  box-shadow: 0 4px 12px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.05),0 0 0 1px #e0e7ff;
  box-shadow: 0 4px 12px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.05),0 0 0 1px var(--primary-100);
  transform: translateY(-2px);
}
.card.elevated {
  background: #fff;
  box-shadow: 0 4px 6px rgba(0,0,0,.05),0 2px 4px rgba(0,0,0,.06),0 0 0 1px rgba(0,0,0,.05);
}
.card.glass {
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: hsla(0,0%,100%,.8);
  border: 1px solid hsla(0,0%,100%,.2);
}
.card:before {
  background: linear-gradient(90deg,transparent,hsla(0,0%,100%,.5),transparent);
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}
.card:hover {
  background: hsla(0,0%,100%,.95);
  border-color: rgba(79,70,229,.2);
  box-shadow: 0 20px 25px rgba(0,0,0,.1),0 10px 10px rgba(0,0,0,.04);
  box-shadow: var(--shadow-xl);
  transform: translateY(-4px);
}
@media (max-width:768px) {
  html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent;
    height: -webkit-fill-available;
    overflow-x: hidden;
  }
  body {
    min-height: -webkit-fill-available;
  }
  .button, a, button, input[type=submit] {
    margin: .25rem 0;
    min-height: 44px;
    padding: .75rem;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }
  input[type=email], input[type=password], input[type=text], textarea {
    -webkit-appearance: none;
    border-radius: 8px;
    font-size: 16px;
    margin: 4px 0;
    padding: 12px;
  }
  .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: contain;
    scroll-behavior: smooth;
  }
  .safe-area-inset {
    height: calc(100vh - env(safe-area-inset-top) - env(safe-area-inset-bottom));
    padding-top: env(safe-area-inset-top);
  }
  #bottom-nav-bar, .safe-area-inset {
    padding-bottom: env(safe-area-inset-bottom);
  }
  #bottom-nav-bar {
    height: calc(60px + env(safe-area-inset-bottom));
  }
  #location-query {
    display: none;
  }
  .button.small {
    font-size: .75rem;
    padding: .25rem .5rem;
  }
  nav .flex-1 {
    gap: .5rem;
    justify-content: flex-end;
  }
  body {
    overscroll-behavior-y: none;
    touch-action: manipulation;
    -webkit-overflow-scrolling: touch;
    -webkit-tap-highlight-color: transparent;
  }
  .container {
    margin: 0 auto;
    max-width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
    width: 100%;
  }
  .h-screen {
    height: 100dvh;
  }
  [role=button], a, button, input[type=button], input[type=submit] {
    margin: .25rem 0;
    min-height: 44px;
    min-width: 44px;
    padding: .75rem;
    touch-action: manipulation;
  }
  input, select, textarea {
    -webkit-appearance: none;
    border-radius: 8px;
    font-size: 16px;
    margin: 4px 0;
    padding: 12px;
    width: 100%;
  }
  .grid {
    gap: 1rem;
    grid-template-columns: 1fr !important;
  }
  .my-20 {
    margin-bottom: 2rem;
    margin-top: 2rem;
  }
  li, p {
    font-size: 16px;
    letter-spacing: .01em;
    line-height: 1.8;
    margin-bottom: 1rem;
  }
  .safe-top {
    padding-top: env(safe-area-inset-top);
  }
  .safe-bottom {
    padding-bottom: env(safe-area-inset-bottom);
  }
  * {
    -webkit-overflow-scrolling: touch;
  }
}
.logo-text, :root, body {
  font-family: Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
}
.logo-text {
  color: var(--manifest-text, #111827);
  font-size: 1.375rem;
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1;
  margin: -.5rem;
  padding: .5rem;
  -webkit-text-decoration: none;
  text-decoration: none;
}
@media (min-width:640px) {
  .logo-text {
    font-size: 1.5rem;
    margin: -.75rem;
    padding: .75rem;
  }
}
.mobileHide {
  display: inline;
}
@media only screen and (min-device-width:320px) and (max-device-width:480px) {
  .mobileHide {
    display: none !important;
  }
}
.alert:empty, [hidden] {
  display: none;
}
.alert.toast.inset-0 {
  transform: translateZ(0);
}
@media (max-width:640px) {
  .alert.toast.inset-0 .max-w-lg {
    border-radius: 0;
    height: 100%;
    margin: 0;
    max-height: calc(100vh - 60px);
  }
  .alert.toast.inset-0 .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .alert.toast.inset-0 .items-center {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  .alert.toast.inset-0 .max-w-lg {
    margin: 1rem;
    width: calc(100% - 2rem);
  }
  .alert.toast.inset-0 .items-center {
    align-items: center;
    padding: 1rem;
  }
}
.alert.toast {
  line-height: 1.5;
}
@media (max-width:640px) {
  .alert.toast.inset-0 .max-w-lg {
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    margin: 1rem;
    max-height: calc(90vh - env(safe-area-inset-bottom));
    overflow: hidden;
    width: calc(100% - 2rem);
  }
  .alert.toast.inset-0 .overflow-y-auto {
    flex: 1;
    height: auto;
    max-height: calc(100vh - 60px - env(safe-area-inset-bottom));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .alert.toast.inset-0 .items-end {
    padding-bottom: env(safe-area-inset-bottom);
  }
}
@media (max-width:768px) {
  .alert.toast.inset-0 {
    bottom: 0;
    height: auto;
    left: 0;
    position: fixed;
    right: 0;
    top: 64px;
  }
  .alert.toast {
    transform: translateZ(0);
  }
}
.alert.toast {
  cursor: pointer;
  font-size: .875rem;
  line-height: 1.25rem;
  margin-top: 5rem;
  position: fixed;
  right: 0;
  top: 0;
  width: 16rem;
  z-index: 40;
  --tw-shadow: 0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);
  box-shadow: 0 0 transparent,0 0 transparent,0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
  transition-duration: .3s;
  transition-timing-function: cubic-bezier(0,0,.2,1);
}
span.invalid-feedback {
  --tw-text-opacity: 1;
  color: #dc2626;
  color: rgba(220,38,38,var(--tw-text-opacity));
}
.phx-click-loading {
  opacity: .5;
  transition: opacity 1s ease-out;
}
.phx-disconnected {
  cursor: wait;
}
.phx-disconnected * {
  pointer-events: none;
}
button[type=submit] {
  cursor: pointer;
}
.fixed.modal-container, .modal-container.inset-0 {
  transform: translateZ(0);
}
@media (max-width:640px) {
  .fixed.modal-container .max-w-lg, .modal-container.inset-0 .max-w-lg {
    border-radius: 0;
    height: 100%;
    margin: 0;
    max-height: calc(100vh - 60px);
  }
  .fixed.modal-container .overflow-y-auto, .modal-container.inset-0 .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .fixed.inset-0 .modal-container, .fixed.modal-container .items-center, .modal-container.inset-0 .items-center {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  .fixed.modal-container .max-w-lg, .modal-container.inset-0 .max-w-lg {
    margin: 1rem;
    width: calc(100% - 2rem);
  }
  .fixed.inset-0 .modal-container, .fixed.modal-container .items-center, .modal-container.inset-0 .items-center {
    align-items: center;
    padding: 1rem;
  }
}
@media (max-width:640px) {
  .flex.modal-container.justify-between.p-4, .modal-container.items-center.justify-between.p-4 {
    margin: .5rem 0;
    padding: 1rem;
  }
  .fixed.modal-container .max-w-lg, .modal-container.inset-0 .max-w-lg {
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    margin: 1rem;
    max-height: calc(90vh - env(safe-area-inset-bottom));
    overflow: hidden;
    width: calc(100% - 2rem);
  }
  .fixed.modal-container .overflow-y-auto, .modal-container.inset-0 .overflow-y-auto {
    overflow-y: auto;
  }
  .fixed.modal-container .overflow-y-auto, .modal-container.inset-0 .overflow-y-auto {
    flex: 1;
    height: auto;
    max-height: calc(100vh - 60px - env(safe-area-inset-bottom));
  }
  .fixed.modal-container .overflow-y-auto, .modal-container.inset-0 .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .fixed.modal-container .items-end, .modal-container.inset-0 .items-end {
    padding-bottom: env(safe-area-inset-bottom);
  }
}
@media (max-width:768px) {
  .fixed.modal-container, .modal-container.inset-0 {
    bottom: 0;
    height: auto;
    left: 0;
    position: fixed;
    right: 0;
    top: 64px;
  }
  .modal-container.flex-col.h-full {
    height: calc(100vh - 64px);
    max-height: calc(100vh - 64px);
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
  .modal-container {
    transform: translateZ(0);
  }
}
.modal-container {
  align-items: center;
  bottom: 0;
  display: flex;
  justify-content: center;
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 50;
}
.fixed.modal-backdrop, .modal-backdrop.inset-0 {
  transform: translateZ(0);
}
@media (max-width:640px) {
  .fixed.modal-backdrop .max-w-lg, .modal-backdrop.inset-0 .max-w-lg {
    border-radius: 0;
    height: 100%;
    margin: 0;
    max-height: calc(100vh - 60px);
  }
  .fixed.modal-backdrop .overflow-y-auto, .modal-backdrop.inset-0 .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .fixed.modal-backdrop .items-center, .modal-backdrop.inset-0 .items-center {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  .fixed.modal-backdrop .max-w-lg, .modal-backdrop.inset-0 .max-w-lg {
    margin: 1rem;
    width: calc(100% - 2rem);
  }
  .fixed.modal-backdrop .items-center, .modal-backdrop.inset-0 .items-center {
    align-items: center;
    padding: 1rem;
  }
}
@media (max-width:640px) {
  .fixed.modal-backdrop .max-w-lg, .modal-backdrop.inset-0 .max-w-lg {
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    margin: 1rem;
    max-height: calc(90vh - env(safe-area-inset-bottom));
    overflow: hidden;
    width: calc(100% - 2rem);
  }
  .fixed.modal-backdrop .overflow-y-auto, .modal-backdrop.inset-0 .overflow-y-auto {
    overflow-y: auto;
  }
  .fixed.modal-backdrop .overflow-y-auto, .modal-backdrop.inset-0 .overflow-y-auto {
    flex: 1;
    height: auto;
    max-height: calc(100vh - 60px - env(safe-area-inset-bottom));
  }
  .fixed.modal-backdrop .overflow-y-auto, .modal-backdrop.inset-0 .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .fixed.modal-backdrop .items-end, .modal-backdrop.inset-0 .items-end {
    padding-bottom: env(safe-area-inset-bottom);
  }
}
@media (max-width:768px) {
  .fixed.modal-backdrop, .modal-backdrop.inset-0 {
    bottom: 0;
    height: auto;
    left: 0;
    position: fixed;
    right: 0;
    top: 64px;
  }
  .modal-backdrop {
    transform: translateZ(0);
  }
}
.modal-backdrop {
  bottom: 0;
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  --tw-bg-opacity: 1;
  background-color: rgba(0,0,0,.75);
  background-color: rgba(0,0,0,var(--tw-bg-opacity));
  --tw-bg-opacity: 0.75;
}
@media (max-width:640px) {
  .fixed.inset-0 .modal-content {
    border-radius: 0;
    height: 100%;
    margin: 0;
    max-height: calc(100vh - 60px);
  }
}
@media (max-width:768px) {
  .fixed.inset-0 .modal-content {
    margin: 1rem;
    width: calc(100% - 2rem);
  }
}
@media (max-width:640px) {
  .fixed.inset-0 .modal-content {
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    margin: 1rem;
    max-height: calc(90vh - env(safe-area-inset-bottom));
    overflow: hidden;
    width: calc(100% - 2rem);
  }
}
.modal-content {
  border-radius: .75rem;
  margin-left: 1rem;
  margin-right: 1rem;
  max-width: 32rem;
  position: relative;
  width: 100%;
  --tw-bg-opacity: 1;
  background-color: #fff;
  background-color: rgba(255,255,255,var(--tw-bg-opacity));
  --tw-shadow: 0 25px 50px -12px rgba(0,0,0,.25);
  box-shadow: 0 0 transparent,0 0 transparent,0 25px 50px -12px rgba(0,0,0,.25);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
@media (max-width:640px) {
  .modal-content {
    margin-bottom: 5rem;
    max-height: calc(100vh - 10rem - env(safe-area-inset-bottom));
  }
}
@media (max-width:640px) {
  .fixed.inset-0 .max-w-lg #bottom-nav-bar>* {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  .fixed.inset-0 .max-w-lg #bottom-nav-bar>* {
    align-items: center;
    padding: 1rem;
  }
}
@media (max-width:640px) {
  #bottom-nav-bar>.items-center.justify-between.p-4, .flex#bottom-nav-bar>.justify-between.p-4 {
    margin: .5rem 0;
    padding: 1rem;
  }
}
@media (max-width:768px) {
  #bottom-nav-bar>.flex-col.h-full, .flex.flex-col#bottom-nav-bar>* {
    height: calc(100vh - 64px);
    max-height: calc(100vh - 64px);
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
}
#bottom-nav-bar>* {
  align-items: center;
  border: none !important;
  cursor: pointer;
  display: flex;
  height: 100%;
  justify-content: center;
  margin: 0 !important;
  outline: none !important;
  padding-left: 0;
  padding-right: 0;
  width: 100%;
}
#bottom-nav-bar>.active {
  --tw-text-opacity: 1;
  color: #4f46e5;
  color: rgba(79,70,229,var(--tw-text-opacity));
}
#bottom-nav-bar>* svg {
  height: 24px !important;
  width: 24px !important;
}
.button {
  --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;
  transform: translateX(0) translateY(0) rotate(0) skewX(0) skewY(0) scaleX(1) scaleY(1);
  transform: translateX(var(--tw-translate-x)) translateY(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));
}
.button:hover {
  --tw-translate-y: -0.125rem;
}
.button {
  border-radius: .5rem;
  --tw-shadow: 0 1px 2px 0 rgba(0,0,0,.05);
  box-shadow: 0 0 transparent,0 0 transparent,0 1px 2px 0 rgba(0,0,0,.05);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.button:hover {
  --tw-shadow: 0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
  box-shadow: 0 0 transparent,0 0 transparent,0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.button {
  transition-duration: .15s;
  transition-duration: .2s;
  transition-property: all;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.button.full {
  display: inline-block;
  text-align: center;
  width: 100%;
}
label:hover .toggle-bg.button.primary {
  background-color: var(--manifest-primary-dark, #4338ca);
}
.button.primary {
  --tw-bg-opacity: 1;
  background-color: #6366f1;
  background-color: rgba(99,102,241,var(--tw-bg-opacity));
}
.button.primary:hover {
  --tw-bg-opacity: 1;
  background-color: #4338ca;
  background-color: rgba(67,56,202,var(--tw-bg-opacity));
}
.button.primary {
  --tw-text-opacity: 1;
  color: #fff;
  color: rgba(255,255,255,var(--tw-text-opacity));
  font-weight: 600;
  padding: .5rem 1rem;
}
.subscription-pricing-button {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.5rem;
  margin: 0.5rem;
  min-height: 100px;
  min-width: 160px;
  position: relative;
  background: linear-gradient(135deg,var(--manifest-accent, #6366f1),var(--manifest-primary, #4f46e5));
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(79,70,229,.3);
  color: #fff;
  text-align: center;
  transition: all .3s ease;
  white-space: nowrap;
  gap: 0.5rem;
}
.subscription-pricing-button:hover {
  background: linear-gradient(135deg,var(--manifest-accent-light, #818cf8),var(--manifest-accent, #6366f1));
  box-shadow: 0 6px 20px rgba(79,70,229,.4);
  transform: translateY(-2px);
}
.subscription-pricing-button .pro-label {
  font-size: 0.875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0;
  padding: 0;
  opacity: 0.95;
  line-height: 1;
}
.subscription-pricing-button .price-label {
  font-size: 1.25rem;
  font-weight: 800;
  line-height: 1;
  margin: 0;
  padding: 0;
}
.subscription-pricing-button .description-label {
  font-size: 0.75rem;
  font-weight: 400;
  opacity: 0.9;
  line-height: 1.2;
  margin: 0;
  padding: 0;
  max-width: 140px;
}
.button.subscription-button {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  padding: 1.25rem;
  min-height: 120px;
  min-width: 180px;
  gap: 0.75rem;
  text-align: center;
  white-space: normal;
}
.button.subscription-button .plan-name {
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0;
  line-height: 1;
}
.button.subscription-button .plan-price {
  font-size: 1.5rem;
  font-weight: 800;
  margin: 0;
  line-height: 1;
}
.button.subscription-button .plan-description {
  font-size: 0.875rem;
  font-weight: 400;
  opacity: 0.9;
  line-height: 1.3;
  margin: 0;
}
.button.secondary {
  --tw-bg-opacity: 1;
  background-color: #ec4899;
  background-color: rgba(236,72,153,var(--tw-bg-opacity));
}
.button.secondary:hover {
  --tw-bg-opacity: 1;
  background-color: #be185d;
  background-color: rgba(190,24,93,var(--tw-bg-opacity));
}
.button.secondary {
  --tw-text-opacity: 1;
  color: #fff;
  color: rgba(255,255,255,var(--tw-text-opacity));
  font-weight: 600;
  padding: .5rem 1rem;
}
.button.danger {
  --tw-bg-opacity: 1;
  background-color: #ef4444;
  background-color: rgba(239,68,68,var(--tw-bg-opacity));
}
.button.danger:hover {
  --tw-bg-opacity: 1;
  background-color: #b91c1c;
  background-color: rgba(185,28,28,var(--tw-bg-opacity));
}
.button.danger {
  --tw-text-opacity: 1;
  color: #fff;
  color: rgba(255,255,255,var(--tw-text-opacity));
  padding: .5rem 1rem;
}
.button.black {
  --tw-bg-opacity: 1;
  background-color: #0f172a;
  background-color: rgba(15,23,42,var(--tw-bg-opacity));
}
.button.black:hover {
  --tw-bg-opacity: 1;
  background-color: #334155;
  background-color: rgba(51,65,85,var(--tw-bg-opacity));
}
.button.black {
  --tw-text-opacity: 1;
  color: #fff;
  color: rgba(255,255,255,var(--tw-text-opacity));
  font-weight: 600;
  padding: .5rem 1rem;
}
.button.gray {
  --tw-bg-opacity: 1;
  background-color: #475569;
  background-color: rgba(71,85,105,var(--tw-bg-opacity));
}
.button.gray:hover {
  --tw-bg-opacity: 1;
  background-color: #cbd5e1;
  background-color: rgba(203,213,225,var(--tw-bg-opacity));
}
.button.gray {
  --tw-text-opacity: 1;
  color: #fff;
  color: rgba(255,255,255,var(--tw-text-opacity));
  font-weight: 600;
  padding: .5rem 1rem;
}
.button.small {
  --tw-bg-opacity: 1;
  background-color: #ec4899;
  background-color: rgba(236,72,153,var(--tw-bg-opacity));
}
.button.small:hover {
  --tw-bg-opacity: 1;
  background-color: #be185d;
  background-color: rgba(190,24,93,var(--tw-bg-opacity));
}
.button.small {
  --tw-text-opacity: 1;
  border-radius: 9999px;
  color: #fff;
  color: rgba(255,255,255,var(--tw-text-opacity));
  font-weight: 600;
  padding: .25rem;
}
label:hover .toggle-bg.button.small.primary {
  background-color: var(--manifest-primary-dark, #4338ca);
}
.button.small.primary {
  --tw-bg-opacity: 1;
  background-color: #6366f1;
  background-color: rgba(99,102,241,var(--tw-bg-opacity));
}
.button.small.primary:hover {
  --tw-bg-opacity: 1;
  background-color: #4338ca;
  background-color: rgba(67,56,202,var(--tw-bg-opacity));
}
.button.small.disabled, .button.small.disabled:hover {
  --tw-bg-opacity: 1;
  background-color: #334155;
  background-color: rgba(51,65,85,var(--tw-bg-opacity));
}
.button.attached-t {
  border-radius: 0;
  border-bottom-left-radius: .375rem;
  border-bottom-right-radius: .375rem;
}
.button.attached-l {
  border-radius: 0;
  border-bottom-right-radius: .375rem;
  border-top-right-radius: .375rem;
}
.button.attached-r {
  border-radius: 0;
  border-bottom-left-radius: .375rem;
  border-top-left-radius: .375rem;
}
.button.attached {
  border-radius: 0;
}
.link {
  color: #475569;
  color: rgba(71,85,105,var(--tw-text-opacity));
  cursor: pointer;
}
.link, .link.active {
  --tw-text-opacity: 1;
}
.link.active {
  color: #4f46e5;
  color: rgba(79,70,229,var(--tw-text-opacity));
}
.fit-height {
  max-height: calc(100vh - 9rem);
}
.fit-width {
  max-width: calc(100vw - 5rem);
}
.chat-bubble {
  border-radius: 1.25rem;
  border-radius: var(--border-radius-xl);
  margin: .75rem 0;
  max-width: 85%;
  padding: 1rem 1.25rem;
  position: relative;
  word-wrap: break-word;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-size: .9rem;
  font-weight: 500;
  line-height: 1.5;
  transition: all .3s cubic-bezier(.4,0,.2,1);
  transition: var(--transition);
}
.chat-bubble:before {
  bottom: -8px;
  content: "";
  height: 0;
  position: absolute;
  width: 0;
}
.chat-bubble.sent {
  background: linear-gradient(135deg,#6366f1,#4f46e5);
  background: linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);
  border-bottom-right-radius: .375rem;
  border-bottom-right-radius: var(--border-radius-sm);
  box-shadow: 0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06),0 0 20px rgba(79,70,229,.15);
  box-shadow: var(--shadow-md),0 0 20px rgba(79,70,229,.15);
  color: #fff;
  margin-left: auto;
  transform-origin: bottom right;
}
.chat-bubble.sent:before {
  border-left: 8px solid #4f46e5;
  border-left: 8px solid var(--primary-dark);
  border-top: 8px solid transparent;
  right: 15px;
}
.chat-bubble.sent:hover {
  box-shadow: 0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05),0 0 25px rgba(79,70,229,.25);
  box-shadow: var(--shadow-lg),0 0 25px rgba(79,70,229,.25);
  transform: scale(1.02) translateY(-2px);
}
.chat-bubble.received {
  background: hsla(0,0%,100%,.95);
  border: 1px solid hsla(0,0%,100%,.3);
  border-bottom-left-radius: .375rem;
  border-bottom-left-radius: var(--border-radius-sm);
  box-shadow: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
  color: #1f2937;
  color: var(--neutral-800);
  margin-right: auto;
  transform-origin: bottom left;
}
.chat-bubble.received:before {
  border-right: 8px solid hsla(0,0%,100%,.95);
  border-top: 8px solid transparent;
  left: 15px;
}
.chat-bubble.received:hover {
  background: #fff;
  box-shadow: 0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);
  box-shadow: var(--shadow-md);
  transform: scale(1.02) translateY(-2px);
}
.chat-bubble-compact {
  border-radius: 0.75rem;
  max-width: 85%;
  padding: 0.375rem 0.75rem;
  position: relative;
  word-wrap: break-word;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.4;
}
.chat-bubble-compact.sent {
  background: linear-gradient(135deg,var(--manifest-accent, #6366f1),var(--manifest-primary, #4f46e5));
  border-radius: 0.75rem;
  color: var(--manifest-card, #fff);
  margin-left: auto;
}
.chat-bubble-compact.sent.continuation {
  border-top-right-radius: 0.375rem;
  border-bottom-right-radius: 0.375rem;
}
.chat-bubble-compact.received {
  background: hsla(0,0%,100%,.95);
  border: 1px solid rgba(0,0,0,0.05);
  border-radius: 0.75rem;
  color: var(--manifest-text, #1f2937);
  margin-right: auto;
}
.chat-bubble-compact.received.continuation {
  border-top-left-radius: 0.375rem;
  border-bottom-left-radius: 0.375rem;
}
.chat-input-container {
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: hsla(0,0%,100%,.95);
  border: 2px solid hsla(0,0%,100%,.3);
  border-radius: 1.25rem;
  border-radius: var(--border-radius-xl);
  box-shadow: 0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05);
  box-shadow: var(--shadow-lg);
  gap: 1rem;
  gap: var(--spacing-md);
  margin: 1.5rem;
  margin: var(--spacing-lg);
  padding: 1rem;
  padding: var(--spacing-md);
  transition: all .3s cubic-bezier(.4,0,.2,1);
  transition: var(--transition);
}
.chat-input-container:focus-within {
  border-color: #6366f1;
  border-color: var(--primary);
  box-shadow: 0 20px 25px rgba(0,0,0,.1),0 10px 10px rgba(0,0,0,.04),0 0 0 4px rgba(79,70,229,.1);
  box-shadow: var(--shadow-xl),0 0 0 4px rgba(79,70,229,.1);
  transform: translateY(-2px);
}
.chat-input {
  background: transparent;
  border: none;
  color: #1f2937;
  color: var(--neutral-800);
  flex: 1;
  font-size: 16px;
  font-weight: 500;
  outline: none;
  padding: .5rem;
  padding: var(--spacing-sm);
}
.chat-input::-moz-placeholder {
  color: var(--neutral-400);
  font-weight: 400;
}
.chat-input::placeholder {
  color: var(--neutral-400);
  font-weight: 400;
}
.chat-button {
  align-items: center;
  background: var(--manifest-accent, #6366f1);
  border: none;
  border-radius: 1rem;
  border-radius: var(--border-radius-lg);
  box-shadow: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
  color: #fff;
  cursor: pointer;
  display: flex;
  justify-content: center;
  min-height: 44px;
  min-width: 44px;
  padding: 1rem;
  padding: var(--spacing-md);
  transition: all .15s cubic-bezier(.4,0,.2,1);
  transition: var(--transition-fast);
}
.chat-button:hover {
  background: #4f46e5;
  background: var(--primary-dark);
  box-shadow: 0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);
  box-shadow: var(--shadow-md);
}
.chat-button:active {
  transform: scale(.95);
}
@media (max-width:640px) {
  .fixed.inset-0 .max-w-lg {
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    margin: 1rem;
    max-height: calc(90vh - env(safe-area-inset-bottom));
    overflow: hidden;
    width: calc(100% - 2rem);
  }
  .fixed.inset-0 .overflow-y-auto {
    overflow-y: auto;
  }
  .post-actions {
    background: var(--manifest-card, #fff);
    border-top: 1px solid var(--manifest-border, #e5e7eb);
    padding: 1rem;
  }
  .post-content {
    font-size: 1rem;
    padding: 1rem;
  }
  .fixed.inset-0 .overflow-y-auto {
    flex: 1;
    height: auto;
    max-height: calc(100vh - 60px - env(safe-area-inset-bottom));
  }
  .post-content {
    margin: 0;
    padding: .75rem;
  }
  .post-avatar {
    height: 2.5rem;
    width: 2.5rem;
  }
  .post-header {
    border-bottom: 1px solid var(--manifest-bg-muted, #f3f4f6);
    padding: .75rem;
  }
  .post-actions {
    border-top: 1px solid var(--manifest-bg-muted, #f3f4f6);
    margin: 0;
    padding: .75rem;
  }
  .fixed.inset-0 .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .fixed.inset-0 .items-end {
    padding-bottom: env(safe-area-inset-bottom);
  }
  .post-content {
    font-size: 16px;
    line-height: 1.5;
    padding: .5rem 0;
  }
  .post-media {
    border-radius: 12px;
    margin: .5rem 0;
    overflow: hidden;
  }
}
.overflow-y-auto {
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
}
.overflow-y-auto::-webkit-scrollbar {
  display: none;
}
.safe-bottom {
  padding-bottom: env(safe-area-inset-bottom);
}
.chat-input-container {
  align-items: center !important;
  background: var(--manifest-card, #fff) !important;
  border: 2px solid var(--manifest-border, #e5e7eb) !important;
  border-radius: 1.5rem !important;
  box-shadow: 0 2px 4px rgba(0,0,0,.04) !important;
  display: flex !important;
  gap: .5rem !important;
  margin: 1rem .75rem !important;
  padding: .5rem !important;
  transition: all .3s ease !important;
}
.chat-input-container:focus-within {
  border-color: var(--manifest-primary, #4f46e5) !important;
  box-shadow: 0 6px 16px rgba(79,70,229,.12) !important;
  transform: translateY(-1px) !important;
}
.chat-input {
  -webkit-appearance: none !important;
  background: var(--manifest-card, #fff) !important;
  border: 2px solid var(--manifest-border, #e5e7eb) !important;
  border-radius: 1.5rem !important;
  flex: 1 !important;
  font-size: 14px !important;
  outline: none !important;
  padding: .875rem 1.25rem !important;
  transition: all .2s ease !important;
  width: 100%;
}
.chat-input::-moz-placeholder {
  color: var(--manifest-text-muted, #9ca3af);
}
.chat-input::placeholder {
  color: var(--manifest-text-muted, #9ca3af);
}
.chat-button {
  background: var(--manifest-bg-muted, #f3f4f6) !important;
  border-radius: 1rem !important;
  color: var(--manifest-primary, #4f46e5) !important;
  padding: .75rem !important;
  transition: all .2s ease !important;
}
.chat-button:hover {
  background: var(--manifest-border, #e5e7eb) !important;
  transform: translateY(-1px);
}
.chat-button.primary {
  background: var(--manifest-primary, #4f46e5) !important;
  color: var(--manifest-card, #fff) !important;
}
.chat-button.primary:hover {
  background: var(--manifest-primary-dark, #4338ca) !important;
}
.chat-button:hover {
  transform: scale(1.05);
}
.chat-timestamp {
  color: var(--manifest-text-muted, #6b7280);
  font-size: .6875rem;
  margin-top: .125rem;
  opacity: .7;
}
.post-item {
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  background: hsla(0,0%,100%,.9);
  border: 1px solid rgba(229,231,235,.5);
  border-radius: 1rem;
  box-shadow: 0 4px 6px rgba(0,0,0,.05);
  margin-bottom: 1rem;
  padding: 1.25rem;
  transition: all .3s cubic-bezier(.4,0,.2,1);
}
.post-item:hover {
  background: var(--manifest-bg, #f9fafb);
  border-color: rgba(79,70,229,.2);
  box-shadow: 0 8px 15px rgba(0,0,0,.08);
  box-shadow: 0 4px 12px rgba(0,0,0,.05);
  transform: translateY(-2px);
  transform: translateX(4px);
}
@media (max-width:768px) {
  .post-item:hover {
    transform: translateY(-2px);
  }
}
.chat-header {
  background: var(--manifest-card, #fff);
  border-bottom: 1px solid var(--manifest-border, #e5e7eb);
  flex-shrink: 0;
  padding: 1rem;
  position: sticky;
  top: 0;
  z-index: 10;
}
.chat-list {
  overflow-y: auto;
  padding: 1rem;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  flex: 1;
  min-height: 0;
}
.chat-input-fixed {
  background: var(--manifest-card, #fff);
  border-top: 1px solid var(--manifest-border, #e5e7eb);
  bottom: 0;
  flex-shrink: 0;
  padding: .75rem;
  position: sticky;
  z-index: 20;
}
@media (max-width:768px) {
  .chat-list {
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    padding: .75rem .75rem calc(140px + env(safe-area-inset-bottom));
  }
  .chat-input-fixed {
    background: var(--manifest-card, #fff) !important;
    border-top: 1px solid var(--manifest-border, #e5e7eb) !important;
    bottom: calc(60px + env(safe-area-inset-bottom)) !important;
    box-shadow: 0 -2px 8px rgba(0,0,0,.1) !important;
    flex-shrink: 0 !important;
    left: 0 !important;
    margin: 0 !important;
    min-height: 80px !important;
    padding: 0 !important;
    position: fixed !important;
    right: 0 !important;
    width: 100% !important;
    z-index: 40 !important;
  }
  .chat-header {
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    background: hsla(0,0%,100%,.95);
    flex-shrink: 0;
    padding: .75rem;
    position: sticky;
    top: 0;
    z-index: 20;
  }
  .fixed.inset-0 {
    bottom: 0 !important;
    height: auto !important;
    left: 0 !important;
    position: fixed !important;
    right: 0 !important;
    top: 64px !important;
  }
  .chat-bubble {
    margin: .5rem 0;
    max-width: 80%;
    word-wrap: break-word;
    font-size: .875rem;
    line-height: 1.4;
    padding: .625rem .875rem;
    transform: translateZ(0);
    will-change: transform;
  }
  .chat-bubble.sent {
    background: linear-gradient(135deg,#4f46e5,#4338ca);
    border-bottom-right-radius: .25rem;
    box-shadow: 0 2px 8px rgba(79,70,229,.2);
    margin-left: 20%;
  }
  .chat-bubble.received {
    background: #fff;
    border: 1px solid #e5e7eb;
    border-bottom-left-radius: .25rem;
    box-shadow: 0 1px 4px rgba(0,0,0,.08);
    margin-right: 20%;
  }
  .break-words {
    word-break: break-word;
    word-wrap: break-word;
    -webkit-hyphens: auto;
    hyphens: auto;
    line-height: 1.5;
  }
  .flex.flex-col.h-full {
    height: calc(100vh - 64px);
    max-height: calc(100vh - 64px);
    padding-bottom: calc(140px + env(safe-area-inset-bottom));
  }
  .chat-input-container {
    gap: .75rem !important;
    padding: 1rem !important;
  }
  .chat-input {
    -webkit-appearance: none !important;
    border-radius: 1.5rem !important;
    -webkit-border-radius: 1.5rem !important;
    border-width: 2px !important;
    font-size: 16px !important;
    padding: 1rem 1.25rem !important;
  }
  .chat-input:focus {
    -webkit-user-select: text !important;
    -moz-user-select: text !important;
    user-select: text !important;
  }
  .chat-input-container {
    max-width: 100% !important;
    width: 100% !important;
  }
  .chat-input {
    flex: 1 !important;
    min-width: 0 !important;
    width: 100% !important;
  }
  .chat-header button, .chat-list button {
    min-height: 44px;
    min-width: 44px;
    touch-action: manipulation;
  }
  .safe-area-inset {
    padding-bottom: calc(60px + env(safe-area-inset-bottom));
  }
}
.grid-responsive {
  display: grid;
  grid-gap: 1.5rem;
  grid-gap: var(--spacing-lg);
  gap: 1.5rem;
  gap: var(--spacing-lg);
  grid-template-columns: repeat(auto-fit,minmax(300px,1fr));
}
@media (max-width:768px) {
  .grid-responsive {
    gap: 1rem;
    gap: var(--spacing-md);
    grid-template-columns: 1fr;
  }
}
.card-hover {
  transform: translateZ(0);
  transition: all .3s cubic-bezier(.4,0,.2,1);
  will-change: transform,box-shadow;
}
.card-hover:hover {
  box-shadow: 0 20px 40px rgba(0,0,0,.15);
  transform: translateY(-4px) scale(1.02);
}
.button-modern {
  overflow: hidden;
  position: relative;
  transform: translateZ(0);
  transition: all .3s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.button-modern:before {
  background: linear-gradient(90deg,transparent,hsla(0,0%,100%,.3),transparent);
  content: "";
  height: 100%;
  left: -100%;
  position: absolute;
  top: 0;
  transition: left .6s;
  width: 100%;
}
.button-modern:hover:before {
  left: 100%;
}
.button-modern:active {
  transform: scale(.98);
}
.skeleton-modern {
  animation: skeleton-shimmer 1.5s infinite;
  background: linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%);
  background: linear-gradient(90deg,var(--neutral-200) 25%,var(--neutral-100) 50%,var(--neutral-200) 75%);
  background-size: 200% 100%;
  border-radius: 1rem;
  border-radius: var(--border-radius-lg);
}
.form-modern {
  position: relative;
}
.form-modern input, .form-modern textarea {
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  background: hsla(0,0%,100%,.9);
  border: 2px solid #e5e7eb;
  border: 2px solid var(--neutral-200);
  border-radius: 1rem;
  border-radius: var(--border-radius-lg);
  font-size: 16px;
  padding: 1rem 1.25rem;
  transition: all .3s ease;
  width: 100%;
}
.form-modern input:focus, .form-modern textarea:focus {
  background: #fff;
  border-color: #6366f1;
  border-color: var(--primary);
  box-shadow: 0 0 0 4px rgba(79,70,229,.1);
  transform: translateY(-2px);
}
.form-modern label {
  color: #374151;
  color: var(--neutral-700);
  display: block;
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .025em;
  margin-bottom: .5rem;
}
@media (max-width:768px) {
  #bottom-nav-bar {
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    background: hsla(0,0%,100%,.95);
    border-top: 1px solid #f1f5f9;
    border-top: 1px solid var(--border-light);
    box-shadow: 0 -4px 12px rgba(0,0,0,.05),0 -1px 3px rgba(0,0,0,.1);
  }
  .mobile-nav-item {
    align-items: center;
    border-radius: 12px;
    color: #374151;
    color: var(--text-secondary);
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin: 4px;
    min-height: 60px;
    padding: 8px 12px;
    position: relative;
    -webkit-text-decoration: none;
    text-decoration: none;
    touch-action: manipulation;
    transition: all .2s cubic-bezier(.4,0,.2,1);
    -webkit-tap-highlight-color: transparent;
  }
  .mobile-nav-item:hover {
    background: #eef2ff;
    background: var(--primary-50);
    color: #6366f1;
    color: var(--primary);
    transform: translateY(-1px);
  }
  .mobile-nav-item.active {
    background: #e0e7ff;
    background: var(--primary-100);
    box-shadow: 0 2px 4px rgba(99,102,241,.15),inset 0 0 0 1px rgba(99,102,241,.1);
    color: #5b21b6;
    color: var(--primary-600);
  }
  .mobile-nav-item:active {
    background: var(--primary-200);
  }
  .mobile-nav-item.active {
    background: rgba(79,70,229,.1);
    color: #6366f1;
    color: var(--primary);
  }
  .mobile-nav-item:active {
    background: rgba(79,70,229,.2);
    transform: scale(.95);
  }
  .mobile-nav-icon {
    height: 24px;
    margin-bottom: .25rem;
    width: 24px;
  }
  .mobile-nav-label {
    font-size: .75rem;
    font-weight: 500;
    text-align: center;
  }
}
.chat-container-modern {
  background: linear-gradient(135deg,#f8fafc,#e2e8f0);
  border-radius: 1.25rem;
  border-radius: var(--border-radius-xl);
  box-shadow: 0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.chat-header-modern {
  align-items: center;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: hsla(0,0%,100%,.95);
  border-bottom: 1px solid rgba(0,0,0,.1);
  display: flex;
  gap: 1rem;
  padding: 1rem;
}
.chat-bubble-modern {
  border-radius: 1.25rem;
  border-radius: var(--border-radius-xl);
  margin: .5rem 0;
  max-width: 75%;
  padding: .875rem 1.25rem;
  position: relative;
  word-wrap: break-word;
  animation: chatSlideIn .3s ease-out;
  box-shadow: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
  font-size: .9rem;
  line-height: 1.5;
}
.chat-bubble-modern.sent {
  background: linear-gradient(135deg,#6366f1,#4f46e5);
  background: linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);
  border-bottom-right-radius: .375rem;
  border-bottom-right-radius: var(--border-radius-sm);
  color: #fff;
  margin-left: auto;
}
.chat-bubble-modern.received {
  background: #fff;
  border: 1px solid #e5e7eb;
  border: 1px solid var(--neutral-200);
  border-bottom-left-radius: .375rem;
  border-bottom-left-radius: var(--border-radius-sm);
  color: #1f2937;
  color: var(--neutral-800);
  margin-right: auto;
}
@keyframes chatSlideIn {
  0% {
    opacity: 0;
    transform: translateY(20px) scale(.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.post-card-modern {
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: hsla(0,0%,100%,.95);
  border: 1px solid hsla(0,0%,100%,.3);
  border-radius: 1.25rem;
  border-radius: var(--border-radius-xl);
  box-shadow: 0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06);
  box-shadow: var(--shadow-md);
  overflow: hidden;
  position: relative;
  transition: all .3s cubic-bezier(.4,0,.2,1);
}
.post-card-modern:before {
  background: linear-gradient(90deg,transparent,hsla(0,0%,100%,.8),transparent);
  content: "";
  height: 1px;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}
.post-card-modern:hover {
  border-color: rgba(79,70,229,.3);
  box-shadow: 0 20px 25px rgba(0,0,0,.1),0 10px 10px rgba(0,0,0,.04);
  box-shadow: var(--shadow-xl);
  transform: translateY(-4px);
}
.post-header-modern {
  align-items: center;
  display: flex;
  gap: .75rem;
  padding: 1.25rem 1.25rem .75rem;
}
.post-avatar-modern {
  border: 2px solid #fff;
  border-radius: 50%;
  box-shadow: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
  height: 3rem;
  width: 3rem;
}
.post-content-modern {
  color: #1f2937;
  color: var(--neutral-800);
  font-size: 1rem;
  line-height: 1.6;
  padding: 0 1.25rem 1rem;
}
.post-actions-modern {
  align-items: center;
  border-top: 1px solid #f3f4f6;
  border-top: 1px solid var(--neutral-100);
  display: flex;
  justify-content: space-between;
  padding: .75rem 1.25rem 1.25rem;
}
.vote-button-modern {
  align-items: center;
  background: #f3f4f6;
  background: var(--neutral-100);
  border: none;
  border-radius: 1rem;
  border-radius: var(--border-radius-lg);
  color: #4b5563;
  color: var(--neutral-600);
  cursor: pointer;
  display: flex;
  font-weight: 500;
  gap: .5rem;
  padding: .5rem .75rem;
  transition: all .3s ease;
}
.vote-button-modern:hover {
  background: #e5e7eb;
  background: var(--neutral-200);
  transform: translateY(-1px);
}
.vote-button-modern.active.upvote {
  background: rgba(79,70,229,.1);
  color: #6366f1;
  color: var(--primary);
}
.vote-button-modern.active.downvote {
  background: rgba(239,68,68,.1);
  color: #dc2626;
  color: var(--error);
}
@media (max-width:768px) {
  .touch-target {
    min-height: 48px;
    min-width: 48px;
    padding: .75rem;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }
  .scroll-smooth {
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: contain;
  }
  h1 {
    font-size: 1.875rem;
    line-height: 1.2;
  }
  h2 {
    font-size: 1.5rem;
    line-height: 1.3;
  }
  h3 {
    font-size: 1.25rem;
    line-height: 1.4;
  }
  p {
    font-size: 1rem;
    line-height: 1.6;
  }
  .mobile-spacing {
    margin: .5rem 0;
    padding: 1rem;
  }
  .tap-feedback:active {
    opacity: .8;
    transform: scale(.98);
  }
  .form-group-mobile {
    margin-bottom: 1.25rem;
  }
  .form-group-mobile label {
    margin-bottom: .5rem;
  }
  .form-group-mobile input, .form-group-mobile textarea {
    border-radius: 1rem;
    border-radius: var(--border-radius-lg);
    font-size: 16px;
    padding: 1rem;
  }
}
.grid-2 {
  grid-template-columns: repeat(2,1fr);
  grid-gap: 1.5rem;
  grid-gap: var(--spacing-lg);
}
.grid-2, .grid-3 {
  display: grid;
  gap: 1.5rem;
  gap: var(--spacing-lg);
}
.grid-3 {
  grid-template-columns: repeat(3,1fr);
  grid-gap: 1.5rem;
  grid-gap: var(--spacing-lg);
}
.grid-4 {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  grid-gap: 1.5rem;
  grid-gap: var(--spacing-lg);
  gap: 1.5rem;
  gap: var(--spacing-lg);
}
@media (max-width:768px) {
  .grid-2, .grid-3, .grid-4 {
    gap: 1rem;
    gap: var(--spacing-md);
    grid-template-columns: 1fr;
  }
}
@media (min-width:769px) and (max-width:1024px) {
  .grid-3, .grid-4 {
    grid-template-columns: repeat(2,1fr);
  }
}
.container, .container-sm {
  padding: 0 1rem;
}
.container-sm {
  max-width: 640px;
}
.container-lg {
  margin: 0 auto;
  max-width: 1400px;
  padding: 0 1rem;
}
.section-padding {
  padding: 3rem 1rem;
}
.section-margin {
  margin: 3rem 0;
}
.space-y-4>*+* {
  margin-top: 1rem;
}
.space-y-6>*+* {
  margin-top: 1.5rem;
}
.space-y-8>*+* {
  margin-top: 2rem;
}
.grid {
  grid-gap: 1.5rem;
  gap: 1.5rem;
}
.grid-cols-1 {
  grid-template-columns: repeat(1,1fr);
}
@media (hover: none) and (pointer: coarse) {
  button[type="submit"] {
    min-height: 56px !important;
    padding: 16px 24px !important;
    font-size: 16px !important;
    touch-action: manipulation !important;
    -webkit-tap-highlight-color: rgba(79, 70, 229, 0.3) !important;
    -webkit-user-select: none !important;
    -webkit-touch-callout: none !important;
    -webkit-appearance: none !important;
    border: none !important;
    outline: none !important;
  }
  button[type="submit"]:active {
    transform: scale(0.98) !important;
    opacity: 0.9 !important;
  }
}
.grid-cols-2 {
  grid-template-columns: repeat(2,1fr);
}
.grid-cols-3 {
  grid-template-columns: repeat(3,1fr);
}
@media (max-width:768px) {
  .section-padding {
    padding: 2rem 1rem;
  }
  .section-margin {
    margin: 2rem 0;
  }
  .grid-cols-2, .grid-cols-3 {
    grid-template-columns: 1fr;
  }
  .container, .container-lg, .container-sm {
    padding: 0 1rem;
  }
  .section-padding {
    padding: 1.5rem 1rem;
    padding: var(--spacing-lg) var(--spacing-md);
  }
  .section-margin {
    margin: 1.5rem 0;
    margin: var(--spacing-lg) 0;
  }
}
.container-fluid {
  max-width: 1400px;
}
.container, .container-fluid {
  margin: 0 auto;
  padding: 0 1.5rem;
  padding: 0 var(--spacing-lg);
  width: 100%;
}
.container {
  max-width: 1200px;
}
.container-sm {
  margin: 0 auto;
  max-width: 800px;
  padding: 0 1.5rem;
  padding: 0 var(--spacing-lg);
  width: 100%;
}
@media (max-width:768px) {
  .container, .container-fluid, .container-sm {
    padding: 0 1rem;
    padding: 0 var(--spacing-md);
  }
}
@media (prefers-reduced-motion:reduce) {
  *, :after, :before {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }
}
@media (prefers-contrast:high) {
  :root {
    --primary: #00f;
    --primary-dark: navy;
    --accent: red;
    --neutral-200: #000;
    --neutral-800: #fff;
  }
  .button, .card, input, textarea {
    border-width: 2px;
  }
}
:focus-visible {
  border-radius: .375rem;
  border-radius: var(--border-radius-sm);
  outline: 3px solid #6366f1;
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}
.button:focus-visible, a:focus-visible, button:focus-visible {
  outline: 3px solid #6366f1;
  outline: 3px solid var(--primary);
  outline-offset: 3px;
}
.sr-only {
  border: 0;
}
.skip-link {
  background: var(--manifest-accent, #6366f1);
  border-radius: .375rem;
  border-radius: var(--border-radius-sm);
  color: #fff;
  left: 6px;
  padding: 8px;
  position: absolute;
  -webkit-text-decoration: none;
  text-decoration: none;
  top: -40px;
  z-index: 70;
}
.skip-link:focus {
  top: 6px;
}
@media (max-width:768px) {
  .mobile-nav {
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    background: hsla(0,0%,100%,.95);
    border-top: 1px solid rgba(0,0,0,.1);
    box-shadow: 0 -4px 20px rgba(0,0,0,.1);
  }
  .mobile-nav-item {
    position: relative;
  }
  .mobile-nav-item:after {
    background: #6366f1;
    background: var(--primary);
    bottom: 0;
    content: "";
    height: 2px;
    left: 50%;
    position: absolute;
    transform: translateX(-50%);
    transition: all .3s ease;
    width: 0;
  }
  .mobile-nav-item.active:after {
    width: 80%;
  }
  .mobile-nav-item:active {
    background: rgba(79,70,229,.15);
  }
}
.loading-spinner {
  animation: spin 1s linear infinite;
  border: 3px solid #e5e7eb;
  border-top: 3px solid #6366f1;
  border: 3px solid var(--neutral-200);
  border-radius: 50%;
  border-top-color: var(--primary);
  height: 2rem;
  margin: 1rem auto;
  width: 2rem;
}
.progress-bar {
  background: #e5e7eb;
  background: var(--neutral-200);
  border-radius: 2px;
  height: 4px;
  overflow: hidden;
  width: 100%;
}
.progress-bar-fill {
  background: linear-gradient(90deg,#6366f1,#818cf8);
  background: linear-gradient(90deg,var(--primary),var(--primary-light));
  border-radius: 2px;
  height: 100%;
  transition: width .3s ease;
}
.toast {
  animation: toastSlideIn .3s ease-out;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: hsla(0,0%,100%,.95);
  border-left: 4px solid #6366f1;
  border-left: 4px solid var(--primary);
  border-radius: 1rem;
  border-radius: var(--border-radius-lg);
  box-shadow: 0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05);
  box-shadow: var(--shadow-lg);
  max-width: 400px;
  padding: 1rem 1.25rem;
  position: fixed;
  right: 1rem;
  top: 1rem;
  z-index: 70;
}
.toast.success {
  border-left-color: #059669;
  border-left-color: var(--success);
}
.toast.error {
  border-left-color: #dc2626;
  border-left-color: var(--error);
}
.toast.warning {
  border-left-color: #f59e0b;
  border-left-color: var(--warning);
}
@keyframes toastSlideIn {
  0% {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@media (max-width:768px) {
  .toast {
    bottom: calc(80px + env(safe-area-inset-bottom));
    left: 1rem;
    max-width: none;
    right: 1rem;
    top: auto;
  }
  .hide-on-mobile {
    display: none !important;
  }
}
@media (min-width:769px) {
  .show-on-mobile {
    display: none !important;
  }
}
@media (min-width:769px) and (max-width:1024px) {
  .hide-on-tablet {
    display: none !important;
  }
}
@media (max-width:768px),(min-width:1025px) {
  .show-on-tablet {
    display: none !important;
  }
}
@media (min-width:1025px) {
  .hide-on-desktop {
    display: none !important;
  }
}
@media (max-width:1024px) {
  .show-on-desktop {
    display: none !important;
  }
}
.text-gradient {
  background: linear-gradient(135deg,#6366f1,#ec4899);
  background: linear-gradient(135deg,var(--primary) 0,var(--accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
}
.text-shadow {
  text-shadow: 0 2px 4px rgba(0,0,0,.1);
}
.text-shadow-lg {
  text-shadow: 0 4px 8px rgba(0,0,0,.2);
}
:focus {
  outline: 2px solid #6366f1;
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.button:focus, button:focus, input:focus, select:focus, textarea:focus {
  box-shadow: 0 0 0 4px rgba(79,70,229,.2);
  outline: none;
}
.skeleton {
  animation: skeleton-loading 1.5s infinite;
  background: linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);
  background-size: 200% 100%;
}
@keyframes skeleton-loading {
  0% {
    background-position: 200% 0;
  }
  to {
    background-position: -200% 0;
  }
}
.spinner {
  animation: spin 1s linear infinite;
  border: 2px solid #e5e7eb;
  border-top: 2px solid #6366f1;
  border: 2px solid var(--neutral-200);
  border-radius: 50%;
  border-top-color: var(--primary);
  height: 24px;
  width: 24px;
}
.hover\:scale-102:hover {
  transform: scale(1.02);
}
.network-card {
  border-radius: .75rem;
  transition-property: all;
}
.network-card:hover {
  --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;
  transform: translateX(0) translateY(0) rotate(0) skewX(0) skewY(0) scaleX(1) scaleY(1);
  transform: translateX(var(--tw-translate-x)) translateY(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: translateY(-2px);
}
.network-button {
  border-radius: 9999px;
  font-size: .875rem;
  line-height: 1.5;
  line-height: 1.25rem;
}
.page-container {
  margin: 0 auto;
  max-width: 1200px;
  padding: 1rem;
  width: 100%;
}
.nearby-header-card {
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: hsla(0,0%,100%,.95);
  border: 1px solid hsla(0,0%,100%,.2);
  border-radius: 1.5rem;
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
  margin-bottom: 1.5rem;
  padding: 1.5rem;
  width: 100%;
}
.nearby-header-content {
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: space-between;
  width: 100%;
}
.card-header-text {
  flex: 1;
  min-width: 200px;
}
.card-header-text h2 {
  color: #111827 !important;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: .25rem;
}
.card-header-text p {
  color: #6b7280 !important;
  font-size: .875rem;
  line-height: 1.4;
  margin: 0;
}
.toggle-container {
  align-items: center;
  display: flex;
  flex-shrink: 0;
  justify-content: center;
}
.toggle-button {
  align-items: center;
  background: transparent;
  border: none;
  border-radius: .75rem;
  cursor: pointer;
  display: flex;
  outline: none;
  padding: .5rem;
  transition: all .2s ease;
}
.toggle-button:hover {
  background: rgba(79,70,229,.05);
}
.toggle-switch {
  background: var(--manifest-accent, #6366f1);
  border-radius: .875rem;
  box-shadow: 0 2px 4px rgba(0,0,0,.1);
  height: 1.75rem;
  padding: .125rem;
  position: relative;
  transition: all .2s ease;
  width: 3.5rem;
}
.toggle-switch.inactive {
  background: #d1d5db;
  background: var(--neutral-300);
}
.toggle-dot {
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 4px rgba(0,0,0,.2);
  height: 1.25rem;
  left: .25rem;
  position: absolute;
  top: .25rem;
  transform: translateX(1.75rem);
  transition: transform .2s ease;
  width: 1.25rem;
}
.toggle-dot.inactive {
  transform: translateX(0);
}
.toggle-label {
  color: #6366f1;
  color: var(--primary);
  font-size: .875rem;
  font-weight: 500;
  margin-left: .75rem;
  white-space: nowrap;
}
.network-container {
  margin: 0 auto;
  max-width: 768px;
  padding: 1rem;
  width: 100%;
}
.network-header {
  padding: 0 1rem;
}
.network-header h1 {
  color: #1f2937 !important;
  font-size: 1.75rem;
  line-height: 1.2;
}
.network-header p {
  color: #4b5563 !important;
  font-size: 1rem;
  line-height: 1.5;
  margin: 0;
}
.google-connect-button {
  align-items: center;
  background: linear-gradient(135deg,#6366f1,#4f46e5);
  background: linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);
  border: none;
  border-radius: 1rem;
  box-shadow: 0 4px 12px rgba(79,70,229,.3);
  color: #fff;
  display: flex;
  font-size: 1rem;
  font-weight: 600;
  gap: .75rem;
  justify-content: center;
  margin-bottom: 2rem;
  min-height: 56px;
  padding: 1rem 1.5rem;
  -webkit-text-decoration: none;
  text-decoration: none;
  transition: all .3s ease;
  width: 100%;
}
.google-connect-button:hover {
  background: linear-gradient(135deg,#818cf8,#6366f1);
  background: linear-gradient(135deg,var(--primary-light) 0,var(--primary) 100%);
  box-shadow: 0 6px 20px rgba(79,70,229,.4);
  transform: translateY(-2px);
}
.google-connect-button:active {
  transform: translateY(0);
}
.google-connect-button svg {
  flex-shrink: 0;
  height: 1.25rem;
  width: 1.25rem;
}
@media (max-width:768px) {
  .page-container {
    padding: .75rem;
  }
  .nearby-header-card {
    border-radius: 1.25rem;
    margin-bottom: 1rem;
    padding: 1.25rem;
  }
  .nearby-header-content {
    align-items: center;
    flex-direction: column;
    gap: 1.25rem;
    text-align: center;
  }
  .card-header-text {
    text-align: center;
    width: 100%;
  }
  .card-header-text h2 {
    font-size: 1.375rem;
  }
  .card-header-text p {
    font-size: .875rem;
    margin-top: .5rem;
  }
  .toggle-container {
    justify-content: center;
    width: 100%;
  }
  .toggle-label {
    font-size: .875rem;
    margin-left: .75rem;
  }
  .network-container {
    padding: .75rem;
  }
  .network-header {
    margin-bottom: 1.5rem;
    padding: 0;
  }
  .network-header h1 {
    font-size: 1.5rem;
  }
  .network-header p {
    font-size: .9375rem;
  }
  .google-connect-button {
    font-size: .9375rem;
    margin-bottom: 1.5rem;
    min-height: 52px;
    padding: 1rem 1.25rem;
  }
  .google-connect-button svg {
    height: 1.125rem;
    width: 1.125rem;
  }
}
@media (max-width:480px) {
  .page-container {
    padding: .5rem;
  }
  .nearby-header-card {
    border-radius: 1rem;
    padding: 1rem;
  }
  .card-header-text h2 {
    font-size: 1.25rem;
  }
  .card-header-text p {
    font-size: .8125rem;
  }
  .network-header h1 {
    font-size: 1.375rem;
  }
  .network-header p {
    font-size: .875rem;
  }
  .google-connect-button {
    font-size: .875rem;
    gap: .5rem;
    min-height: 48px;
    padding: .875rem 1rem;
  }
  .toggle-switch {
    height: 1.5rem;
    width: 3rem;
  }
  .toggle-dot {
    height: 1rem;
    transform: translateX(1.5rem);
    width: 1rem;
  }
  .toggle-dot.inactive {
    transform: translateX(0);
  }
  .toggle-label {
    font-size: .8125rem;
  }
}
@media (min-width:769px) and (max-width:1024px) {
  .page-container {
    padding: 1.25rem;
  }
  .nearby-header-card {
    padding: 1.75rem;
  }
  .network-container {
    padding: 1.25rem;
  }
}
@media (min-width:1025px) {
  .page-container {
    padding: 1.5rem;
  }
  .nearby-header-card {
    padding: 2rem;
  }
  .network-container {
    padding: 1.5rem;
  }
  .nearby-header-content {
    align-items: center;
  }
  .card-header-text {
    text-align: left;
  }
}
.toggle-button:focus-visible {
  outline: 2px solid #6366f1;
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.google-connect-button:focus-visible {
  outline: 2px solid #818cf8;
  outline: 2px solid var(--primary-light);
  outline-offset: 2px;
}
.google-connect-button:disabled {
  cursor: not-allowed;
  opacity: .7;
  transform: none;
}
.google-connect-button:disabled:hover {
  box-shadow: 0 4px 12px rgba(79,70,229,.3);
  transform: none;
}
@media (max-width:768px) {
  input[type=email], input[type=password], input[type=text], textarea {
    padding: .75rem;
  }
  .button.small {
    font-size: .875rem;
    padding: .5rem 1rem;
  }
  .link {
    margin: -.5rem;
    padding: .5rem;
  }
  .fixed {
    transform: translateZ(0);
  }
  .button, a, button, input, select {
    margin: .25rem 0;
    min-height: 48px;
    min-width: 48px;
    -webkit-tap-highlight-color: transparent;
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
  }
  .scrollable-content {
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-y: contain;
    scroll-behavior: smooth;
  }
  .button:active, button:active {
    transform: scale(.98);
    transition: transform .1s;
  }
  input[type=email], input[type=password], input[type=text], textarea {
    -webkit-appearance: none;
    border-radius: 8px;
    font-size: 16px;
    margin: 4px 0;
    padding: 12px;
    width: 100%;
  }
  * {
    -webkit-overflow-scrolling: touch;
  }
  .button, a, button, input, select {
    min-height: 44px;
    padding: .75rem;
    touch-action: manipulation;
  }
  input[type=text], input[type=email], input[type=password], textarea {
    border-radius: 8px;
    font-size: 16px;
    padding: 12px;
    width: 100%;
  }
  .button, button, input[type=submit] {
    min-height: 44px;
    padding: .75rem 1rem;
  }
  .my-20 {
    margin-bottom: 4rem;
    margin-top: 4rem;
  }
  .map-sidebar {
    bottom: 0 !important;
    height: 50vh !important;
    max-width: 100% !important;
    position: fixed !important;
    top: auto !important;
    width: 100% !important;
    z-index: 1000 !important;
  }
  .map-search-box {
    background: #f5f5f5 !important;
    border: none !important;
    border-radius: 20px !important;
    box-shadow: none !important;
    color: #333 !important;
    display: inline-block !important;
    font-size: 14px !important;
    margin: 0 4px !important;
    min-height: 0 !important;
    min-height: auto !important;
    padding: 8px 16px !important;
    position: static !important;
    transform: none !important;
    transition: background .2s !important;
    white-space: nowrap !important;
    width: auto !important;
  }
  .map-search-box:focus {
    background: #e0e0e0 !important;
    outline: none !important;
  }
  @media (max-width:768px) {
    .map-shortcuts {
      background: #fff !important;
      border-radius: 8px !important;
      box-shadow: 0 2px 6px rgba(0,0,0,.1) !important;
      grid-template-columns: repeat(3,auto) !important;
      left: 10px !important;
      max-width: 45px !important;
      overflow: hidden !important;
      position: absolute !important;
      top: 70px !important;
      transition: max-width .3s ease !important;
      z-index: 10 !important;
    }
    .map-shortcuts:hover {
      max-width: 200px !important;
    }
    .map-shortcuts button {
      align-items: center !important;
      background: #fff !important;
      border-bottom: 1px solid #eee !important;
      border-radius: 0 !important;
      cursor: pointer !important;
      display: flex !important;
      gap: 8px !important;
      padding: 8px !important;
      text-align: left !important;
      transition: background .2s ease !important;
      width: 200px !important;
    }
    .map-shortcuts button:hover {
      background: #f5f5f5 !important;
    }
    .map-shortcuts button span {
      font-size: 18px !important;
    }
    @media (max-width768px) {
      .map-search-box {
        margin: 8px auto !important;
        width: calc(100% - 32px) !important;
      }
      .map-shortcuts {
        bottom: 20px !important;
        left: 10px !important;
        top: auto !important;
      }
      .map-search-box {
        left: 50% !important;
        max-width: 400px !important;
        position: absolute !important;
        top: 10px !important;
        transform: translateX(-50%) !important;
        width: calc(100% - 20px) !important;
        z-index: 10 !important;
      }
    }
    .search-categories-container {
      background: #fff !important;
      box-shadow: 0 2px 8px rgba(0,0,0,.1) !important;
      left: 0 !important;
      padding: 12px !important;
      position: fixed !important;
      right: 0 !important;
      top: 0 !important;
      z-index: 1000 !important;
    }
    .map-shortcuts {
      display: flex !important;
      flex-wrap: wrap !important;
      gap: 8px !important;
      justify-content: center !important;
      margin-top: 8px !important;
      padding: 4px 0 !important;
    }
    .map-shortcuts::-webkit-scrollbar {
      display: none !important;
    }
    .map-shortcuts button {
      background: #f5f5f5 !important;
      border: none !important;
      border-radius: 20px !important;
      color: #333 !important;
      font-size: 14px !important;
      margin: 0 4px !important;
      padding: 8px 16px !important;
      white-space: nowrap !important;
    }
    .map-shortcuts button:active {
      background: #e0e0e0 !important;
    }
    .gm-style-cc {
      z-index: 10 !important;
    }
  }
}
@supports (-webkit-touch-callout:none) {
  .map-shortcuts {
    grid-template-columns: repeat(3,auto) !important;
    padding: 12px !important;
    top: 70px !important;
  }
}
@media (max-width:768px) {
  .map-shortcuts {
    background: transparent !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
    left: 10px !important;
    max-height: 40px !important;
    overflow: hidden !important;
    padding: 4px !important;
    position: fixed !important;
    top: 70px !important;
    transform: none !important;
    transition: all .3s ease !important;
    width: auto !important;
    z-index: 1000 !important;
  }
  .map-shortcuts:focus-within, .map-shortcuts:hover {
    background: hsla(0,0%,100%,.95) !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 10px rgba(0,0,0,.1) !important;
    max-height: 400px !important;
    padding: 8px !important;
  }
}
.map-shortcuts {
  background: hsla(0,0%,100%,.9) !important;
  border-radius: 8px !important;
  box-shadow: 0 2px 6px rgba(0,0,0,.1) !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  left: 10px !important;
  padding: 10px !important;
  position: fixed !important;
  top: 70px !important;
  z-index: 1000 !important;
}
.map-shortcuts:focus-within, .map-shortcuts:hover {
  background: hsla(0,0%,100%,.9) !important;
  border-radius: 20px !important;
  max-height: 300px !important;
  padding: 8px !important;
}
.map-shortcuts button {
  align-items: center !important;
  background: hsla(0,0%,100%,.9) !important;
  border: none !important;
  border-radius: 12px !important;
  color: #333 !important;
  display: flex !important;
  flex: 0 0 auto !important;
  font-size: 20px !important;
  justify-content: flex-start !important;
  overflow: hidden !important;
  padding: 6px !important;
  touch-action: manipulation !important;
  white-space: nowrap !important;
  width: 36px !important;
}
.map-shortcuts:focus-within button, .map-shortcuts:hover button {
  padding: 6px 12px !important;
  width: auto !important;
}
.map-shortcuts button span {
  font-size: 20px !important;
  margin-right: 8px !important;
}
.map-shortcuts button:hover {
  background: #f5f5f5 !important;
  opacity: 1 !important;
}
.map-shortcuts button.active {
  border-color: #4285f4 !important;
}
.map-shortcuts button:active {
  transform: scale(.95) !important;
}
.map-shortcuts button.active, .map-shortcuts button:active {
  background: #4285f4 !important;
  color: #fff !important;
  transform: scale(.98) !important;
}
.map-shortcuts button span {
  font-size: 16px !important;
}
.map-search-box {
  background: #fff !important;
  border-radius: 24px !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.1) !important;
  font-size: 16px !important;
  height: 48px !important;
  margin: 16px !important;
  max-width: 600px !important;
  padding: 0 20px !important;
  transition: all .3s ease !important;
  width: calc(100% - 32px) !important;
}
.map-search-box:focus {
  box-shadow: 0 4px 16px rgba(0,0,0,.15) !important;
  transform: translateY(-1px) !important;
}
.map-shortcuts button {
  background: #fff !important;
  border-radius: 20px !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.08) !important;
  color: #4285f4 !important;
  font-weight: 500 !important;
  padding: 8px 16px !important;
  transition: all .2s ease !important;
}
.map-shortcuts button:hover {
  transform: translateY(-1px) !important;
}
.map-shortcuts button.active, .map-shortcuts button:hover {
  background: #4285f4 !important;
  color: #fff !important;
}
@media (max-width:768px) {
  .map-search-box {
    border-radius: 22px !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.1) !important;
    font-size: 16px !important;
    height: 44px !important;
    margin: 8px auto !important;
    padding: 8px 16px !important;
    width: calc(100% - 32px) !important;
  }
  .map-shortcuts {
    gap: 8px !important;
    overflow-x: auto !important;
    padding: 8px !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
  }
  .map-shortcuts::-webkit-scrollbar {
    display: none !important;
  }
  .map-shortcuts button {
    border-radius: 22px !important;
    font-size: 14px !important;
    min-height: 44px !important;
    padding: 8px 16px !important;
    touch-action: manipulation !important;
  }
}
@supports (-webkit-touch-callout:none) {
  .map-search-box, .map-shortcuts button {
    -webkit-touch-callout: none !important;
    -webkit-user-select: none !important;
  }
}
@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi) {
  .map-search-box, .map-shortcuts button {
    -webkit-font-smoothing: antialiased !important;
    -moz-osx-font-smoothing: grayscale !important;
  }
}
.gm-style {
  touch-action: pan-x pan-y !important;
}
@media (max-width:768px) {
  .button, .chat-button, .post-actions button, button {
    transform-origin: center;
    transition: all .15s cubic-bezier(.4,0,.2,1);
    transition: var(--transition-fast);
    will-change: transform;
    -webkit-tap-highlight-color: transparent;
  }
  .button:active, .chat-button:active, .post-actions button:active, button:active {
    transform: scale(.95);
  }
}
.vote-animate-up {
  animation: vote-pulse-up .6s cubic-bezier(.68,-.55,.265,1.55);
}
.vote-animate-down {
  animation: vote-pulse-down .6s cubic-bezier(.68,-.55,.265,1.55);
}
@keyframes vote-pulse-up {
  0% {
    transform: scale(1);
  }
  30% {
    color: #6366f1;
    color: var(--primary);
    transform: scale(1.3) rotate(10deg);
  }
  70% {
    transform: scale(1.1) rotate(-5deg);
  }
  to {
    transform: scale(1) rotate(0deg);
  }
}
@keyframes vote-pulse-down {
  0% {
    transform: scale(1);
  }
  30% {
    color: #dc2626;
    color: var(--error);
    transform: scale(1.3) rotate(-10deg);
  }
  70% {
    transform: scale(1.1) rotate(5deg);
  }
  to {
    transform: scale(1) rotate(0deg);
  }
}
.loading-pulse {
  animation: loading-pulse 1.5s ease-in-out infinite;
}
@keyframes loading-pulse {
  0%, to {
    opacity: 1;
  }
  50% {
    opacity: .5;
  }
}
.list-item {
  animation: slideInUp .4s cubic-bezier(.4,0,.2,1);
}
.list-item:first-child {
  animation-delay: .1s;
}
.list-item:nth-child(2) {
  animation-delay: .2s;
}
.list-item:nth-child(3) {
  animation-delay: .3s;
}
.list-item:nth-child(4) {
  animation-delay: .4s;
}
.list-item:nth-child(5) {
  animation-delay: .5s;
}
@keyframes slideInUp {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.viewer-count-animate {
  animation: viewer-count-pulse 0.5s ease-out;
}
@keyframes viewer-count-pulse {
  0% {
    transform: scale(1);
    background-color: rgb(238 242 255);
  }
  50% {
    transform: scale(1.02);
    background-color: rgb(199 210 254);
  }
  100% {
    transform: scale(1);
    background-color: rgb(238 242 255);
  }
}
.fab {
  align-items: center;
  animation: fabBounce 2s infinite;
  background: linear-gradient(135deg,#6366f1,#4f46e5);
  background: linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);
  border: none;
  border-radius: 50%;
  bottom: calc(80px + env(safe-area-inset-bottom));
  box-shadow: 0 10px 15px rgba(0,0,0,.1),0 4px 6px rgba(0,0,0,.05);
  box-shadow: var(--shadow-lg);
  color: #fff;
  display: flex;
  height: 56px;
  justify-content: center;
  position: fixed;
  right: 1.5rem;
  right: var(--spacing-lg);
  transition: all .3s cubic-bezier(.4,0,.2,1);
  transition: var(--transition);
  width: 56px;
  z-index: 1000;
}
.fab:hover {
  box-shadow: 0 20px 25px rgba(0,0,0,.1),0 10px 10px rgba(0,0,0,.04),0 0 20px rgba(79,70,229,.4);
  box-shadow: var(--shadow-xl),0 0 20px rgba(79,70,229,.4);
  transform: scale(1.1);
}
@keyframes fabBounce {
  0%, 20%, 50%, 80%, to {
    transform: translateY(0);
  }
  40% {
    transform: translateY(-10px);
  }
  60% {
    transform: translateY(-5px);
  }
}
html {
  scroll-behavior: smooth;
}
.ripple {
  overflow: hidden;
  position: relative;
}
.ripple:before {
  background: hsla(0,0%,100%,.3);
  border-radius: 50%;
  content: "";
  height: 0;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%,-50%);
  transition: width .6s,height .6s;
  width: 0;
}
.ripple:active:before {
  height: 300px;
  width: 300px;
}
input[type=email], input[type=password], input[type=text], select, textarea {
  background: #fff;
  background: var(--background);
  border: 1px solid #e2e8f0;
  border: 1px solid var(--border);
  border-radius: 12px;
  font-size: 16px;
  padding: 12px 16px;
  transition: all .2s cubic-bezier(.4,0,.2,1);
  -webkit-tap-highlight-color: transparent;
  box-shadow: 0 1px 2px rgba(0,0,0,.05),inset 0 0 0 1px hsla(0,0%,100%,.05);
  color: #111827;
  color: var(--text-primary);
  font-family: inherit;
  font-weight: 500;
  line-height: 1.5;
  width: 100%;
}
input[type=email]:focus, input[type=password]:focus, input[type=text]:focus, select:focus, textarea:focus {
  background: var(--background);
  box-shadow: 0 0 0 3px rgba(99,102,241,.1),0 2px 4px rgba(0,0,0,.05),inset 0 0 0 1px hsla(0,0%,100%,.1);
  transform: translateY(-1px);
}
input[type=email]:hover, input[type=password]:hover, input[type=text]:hover, select:hover, textarea:hover {
  box-shadow: 0 2px 4px rgba(0,0,0,.05),inset 0 0 0 1px hsla(0,0%,100%,.05);
}
input[type=email]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=text]::-moz-placeholder, textarea::-moz-placeholder {
  color: #6b7280;
  color: var(--text-tertiary);
  opacity: 1;
}
input[type=email]::placeholder, input[type=password]::placeholder, input[type=text]::placeholder, textarea::placeholder {
  color: #6b7280;
  color: var(--text-tertiary);
  opacity: 1;
}
input[type=email]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=text]::-moz-placeholder, textarea::-moz-placeholder {
  color: #9ca3af;
  color: var(--neutral-400);
  font-weight: 400;
}
input[type=email]::placeholder, input[type=password]::placeholder, input[type=text]::placeholder, textarea::placeholder {
  color: #9ca3af;
  color: var(--neutral-400);
  font-weight: 400;
}
input[type=email]:hover, input[type=password]:hover, input[type=text]:hover, select:hover, textarea:hover {
  background: #fff;
  border-color: #818cf8;
  border-color: var(--primary-light);
  box-shadow: 0 1px 3px rgba(0,0,0,.1),0 1px 2px rgba(0,0,0,.06);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}
input[type=email]:focus, input[type=password]:focus, input[type=text]:focus, select:focus, textarea:focus {
  background: #fff;
  border-color: #6366f1;
  border-color: var(--primary);
  box-shadow: 0 4px 6px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.06),0 0 0 4px rgba(79,70,229,.1);
  box-shadow: var(--shadow-md),0 0 0 4px rgba(79,70,229,.1);
  outline: none;
  transform: translateY(-2px);
}
label {
  color: #374151;
  color: var(--neutral-700);
  display: block;
  font-size: .875rem;
  font-weight: 600;
  letter-spacing: .025em;
  margin-bottom: .25rem;
  margin-bottom: var(--spacing-xs);
  text-transform: uppercase;
}
.form-group {
  margin-bottom: 1.5rem;
  margin-bottom: var(--spacing-lg);
}
.form-group, .form-group.floating-label {
  position: relative;
}
.form-group.floating-label label {
  background: #fff;
  color: #9ca3af;
  color: var(--neutral-400);
  font-size: 16px;
  font-weight: 400;
  left: 1.25rem;
  padding: 0 .5rem;
  pointer-events: none;
  position: absolute;
  text-transform: none;
  top: 1rem;
  transition: all .15s cubic-bezier(.4,0,.2,1);
  transition: var(--transition-fast);
}
.form-group.floating-label input:not(:-moz-placeholder-shown)+label {
  color: #6366f1;
  color: var(--primary);
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  top: -.5rem;
}
.form-group.floating-label input:focus+label, .form-group.floating-label input:not(:placeholder-shown)+label {
  color: #6366f1;
  color: var(--primary);
  font-size: .75rem;
  font-weight: 600;
  text-transform: uppercase;
  top: -.5rem;
}
.help-list {
  list-style-type: decimal;
  margin-left: 1rem;
}
.help-list, .help-list li {
  margin-bottom: .5rem;
  margin-top: .5rem;
}
.help-list li p {
  margin-bottom: .25rem;
  margin-top: .25rem;
}
.help-list li i {
  border-radius: .25rem;
  border-width: 1px;
  --tw-text-opacity: 1;
  color: #334155;
  color: rgba(51,65,85,var(--tw-text-opacity));
}
.sr-only {
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  clip: rect(0,0,0,0);
  border-width: 0;
  white-space: nowrap;
}
.visible {
  visibility: visible;
}
.invisible {
  visibility: hidden;
}
.fixed {
  position: fixed;
}
.absolute {
  position: absolute;
}
.relative {
  position: relative;
}
.sticky {
  position: sticky;
}
.inset-0 {
  bottom: 0;
  left: 0;
  right: 0;
  top: 0;
}
.top-0 {
  top: 0;
}
.top-4 {
  top: 1rem;
}
.top-10 {
  top: 2.5rem;
}
.top-20 {
  top: 5rem;
}
.-top-1 {
  top: -.25rem;
}
.-top-2 {
  top: -.5rem;
}
.top-1\/2 {
  top: 50%;
}
.right-0 {
  right: 0;
}
.right-3 {
  right: .75rem;
}
.right-4 {
  right: 1rem;
}
.right-10 {
  right: 2.5rem;
}
.-right-1 {
  right: -.25rem;
}
.-right-2 {
  right: -.5rem;
}
.bottom-0 {
  bottom: 0;
}
.bottom-20 {
  bottom: 5rem;
}
.-bottom-1 {
  bottom: -.25rem;
}
.-bottom-6 {
  bottom: -1.5rem;
}
.left-0 {
  left: 0;
}
.left-10 {
  left: 2.5rem;
}
.-left-10 {
  left: -2.5rem;
}
.left-1\/2 {
  left: 50%;
}
.left-1\/4 {
  left: 25%;
}
.z-0 {
  z-index: 0;
}
.z-10 {
  z-index: 10;
}
.z-20 {
  z-index: 20;
}
.z-30 {
  z-index: 30;
}
.z-50 {
  z-index: 50;
}
.z-auto {
  z-index: auto;
}
.order-1 {
  order: 1;
}
.order-2 {
  order: 2;
}
.order-first {
  order: -9999;
}
.m-7 {
  margin: 1.75rem;
}
.mx-4 {
  margin-left: 1rem;
  margin-right: 1rem;
}
.mx-auto {
  margin-left: auto;
  margin-right: auto;
}
.my-1 {
  margin-bottom: .25rem;
  margin-top: .25rem;
}
.my-2 {
  margin-bottom: .5rem;
  margin-top: .5rem;
}
.my-3 {
  margin-bottom: .75rem;
  margin-top: .75rem;
}
.my-4 {
  margin-bottom: 1rem;
  margin-top: 1rem;
}
.my-5 {
  margin-bottom: 1.25rem;
  margin-top: 1.25rem;
}
.my-7 {
  margin-bottom: 1.75rem;
  margin-top: 1.75rem;
}
.my-8 {
  margin-bottom: 2rem;
  margin-top: 2rem;
}
.my-10 {
  margin-bottom: 2.5rem;
  margin-top: 2.5rem;
}
.my-20 {
  margin-bottom: 5rem;
  margin-top: 5rem;
}
.mt-0 {
  margin-top: 0;
}
.mt-1 {
  margin-top: .25rem;
}
.mt-2 {
  margin-top: .5rem;
}
.mt-3 {
  margin-top: .75rem;
}
.mt-4 {
  margin-top: 1rem;
}
.mt-5 {
  margin-top: 1.25rem;
}
.mt-6 {
  margin-top: 1.5rem;
}
.mt-8 {
  margin-top: 2rem;
}
.mt-10 {
  margin-top: 2.5rem;
}
.mt-12 {
  margin-top: 3rem;
}
.mt-32 {
  margin-top: 8rem;
}
.mt-auto {
  margin-top: auto;
}
.mt-0\.5 {
  margin-top: .125rem;
}
.mr-1 {
  margin-right: .25rem;
}
.mr-2 {
  margin-right: .5rem;
}
.mr-3 {
  margin-right: .75rem;
}
.mr-4 {
  margin-right: 1rem;
}
.mr-auto {
  margin-right: auto;
}
.mr-1\.5 {
  margin-right: .375rem;
}
.mb-1 {
  margin-bottom: .25rem;
}
.mb-2 {
  margin-bottom: .5rem;
}
.mb-3 {
  margin-bottom: .75rem;
}
.mb-4 {
  margin-bottom: 1rem;
}
.mb-5 {
  margin-bottom: 1.25rem;
}
.mb-6 {
  margin-bottom: 1.5rem;
}
.mb-8 {
  margin-bottom: 2rem;
}
.mb-10 {
  margin-bottom: 2.5rem;
}
.mb-12 {
  margin-bottom: 3rem;
}
.mb-16 {
  margin-bottom: 4rem;
}
.ml-2 {
  margin-left: .5rem;
}
.ml-3 {
  margin-left: .75rem;
}
.ml-4 {
  margin-left: 1rem;
}
.ml-8 {
  margin-left: 2rem;
}
.block {
  display: block;
}
.inline-block {
  display: inline-block;
}
.flex {
  display: flex;
}
.inline-flex {
  display: inline-flex;
}
.table {
  display: table;
}
.grid {
  display: grid;
}
.hidden {
  display: none;
}
.h-1 {
  height: .25rem;
}
.h-2 {
  height: .5rem;
}
.h-3 {
  height: .75rem;
}
.h-4 {
  height: 1rem;
}
.h-5 {
  height: 1.25rem;
}
.h-6 {
  height: 1.5rem;
}
.h-8 {
  height: 2rem;
}
.h-10 {
  height: 2.5rem;
}
.h-11 {
  height: 2.75rem;
}
.h-12 {
  height: 3rem;
}
.h-14 {
  height: 3.5rem;
}
.h-16 {
  height: 4rem;
}
.h-20 {
  height: 5rem;
}
.h-24 {
  height: 6rem;
}
.h-32 {
  height: 8rem;
}
.h-40 {
  height: 10rem;
}
.h-80 {
  height: 20rem;
}
.h-auto {
  height: auto;
}
.h-2\.5 {
  height: .625rem;
}
.h-full {
  height: 100%;
}
.max-h-96 {
  max-height: 24rem;
}
.max-h-screen {
  max-height: 100vh;
}
.min-h-full {
  min-height: 100%;
}
.min-h-screen {
  min-height: 100vh;
}
.w-2 {
  width: .5rem;
}
.w-3 {
  width: .75rem;
}
.w-4 {
  width: 1rem;
}
.w-5 {
  width: 1.25rem;
}
.w-6 {
  width: 1.5rem;
}
.w-8 {
  width: 2rem;
}
.w-10 {
  width: 2.5rem;
}
.w-12 {
  width: 3rem;
}
.w-14 {
  width: 3.5rem;
}
.w-16 {
  width: 4rem;
}
.w-20 {
  width: 5rem;
}
.w-24 {
  width: 6rem;
}
.w-40 {
  width: 10rem;
}
.w-80 {
  width: 20rem;
}
.w-auto {
  width: auto;
}
.w-px {
  width: 1px;
}
.w-full {
  width: 100%;
}
.w-screen {
  width: 100vw;
}
.min-w-0 {
  min-width: 0;
}
.min-w-full {
  min-width: 100%;
}
.max-w-none {
  max-width: none;
}
.max-w-xs {
  max-width: 20rem;
}
.max-w-sm {
  max-width: 24rem;
}
.max-w-md {
  max-width: 28rem;
}
.max-w-lg {
  max-width: 32rem;
}
.max-w-2xl {
  max-width: 42rem;
}
.max-w-3xl {
  max-width: 48rem;
}
.max-w-4xl {
  max-width: 56rem;
}
.max-w-5xl {
  max-width: 64rem;
}
.max-w-6xl {
  max-width: 72rem;
}
.max-w-7xl {
  max-width: 80rem;
}
.max-w-full {
  max-width: 100%;
}
.flex-1 {
  flex: 1 1 0%;
}
.flex-shrink-0 {
  flex-shrink: 0;
}
.flex-grow {
  flex-grow: 1;
}
.table-auto {
  table-layout: auto;
}
.origin-top-right {
  transform-origin: top right;
}
.transform {
  --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;
  transform: translateX(0) translateY(0) rotate(0) skewX(0) skewY(0) scaleX(1) scaleY(1);
  transform: translateX(var(--tw-translate-x)) translateY(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\/3 {
  --tw-translate-x: 33.333333%;
}
.-translate-x-1\/2 {
  --tw-translate-x: -50%;
}
.translate-y-1\/3 {
  --tw-translate-y: 33.333333%;
}
.-translate-y-1\/2 {
  --tw-translate-y: -50%;
}
.hover\:-translate-y-0:hover {
  --tw-translate-y: 0px;
}
.hover\:-translate-y-1:hover {
  --tw-translate-y: -0.25rem;
}
.hover\:-translate-y-0\.5:hover {
  --tw-translate-y: -0.125rem;
}
.rotate-3 {
  --tw-rotate: 3deg;
}
.rotate-180 {
  --tw-rotate: 180deg;
}
.scale-95 {
  --tw-scale-x: .95;
  --tw-scale-y: .95;
}
.scale-100 {
  --tw-scale-x: 1;
  --tw-scale-y: 1;
}
.hover\:scale-105:hover {
  --tw-scale-x: 1.05;
  --tw-scale-y: 1.05;
}
@keyframes spin {
  to {
    transform: rotate(1turn);
  }
}
@keyframes ping {
  75%, to {
    opacity: 0;
    transform: scale(2);
  }
}
@keyframes bounce {
  0%, to {
    animation-timing-function: cubic-bezier(.8,0,1,1);
    transform: translateY(-25%);
  }
  50% {
    animation-timing-function: cubic-bezier(0,0,.2,1);
    transform: none;
  }
}
@keyframes pulse {
  50% {
    opacity: .5;
  }
}
.animate-spin {
  animation: spin 1s linear infinite;
}
.animate-ping {
  animation: ping 1s cubic-bezier(0,0,.2,1) infinite;
}
.animate-pulse {
  animation: pulse 2s cubic-bezier(.4,0,.6,1) infinite;
}
.animate-vote-twice {
  animation: pulse 1s ease-in 2;
}
@keyframes bounce-in {
  0% {
    opacity: 0;
    transform: scale(0.3) translateY(-50px);
  }
  50% {
    opacity: 1;
    transform: scale(1.05);
  }
  70% {
    transform: scale(0.9);
  }
  100% {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}
.animate-bounce-in {
  animation: bounce-in 0.6s cubic-bezier(0.68, -0.55, 0.265, 1.55) forwards;
}
.cursor-pointer {
  cursor: pointer;
}
.cursor-not-allowed {
  cursor: not-allowed;
}
.select-none {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}
.resize-none {
  resize: none;
}
.list-disc {
  list-style-type: disc;
}
.grid-cols-1 {
  grid-template-columns: repeat(1,minmax(0,1fr));
}
.grid-cols-2 {
  grid-template-columns: repeat(2,minmax(0,1fr));
}
.flex-col {
  flex-direction: column;
}
.flex-wrap {
  flex-wrap: wrap;
}
.items-start {
  align-items: flex-start;
}
.items-end {
  align-items: flex-end;
}
.items-center {
  align-items: center;
}
.justify-end {
  justify-content: flex-end;
}
.justify-center {
  justify-content: center;
}
.justify-between {
  justify-content: space-between;
}
.justify-evenly {
  justify-content: space-evenly;
}
.gap-1 {
  gap: .25rem;
}
.gap-2 {
  gap: .5rem;
}
.gap-3 {
  gap: .75rem;
}
.gap-4 {
  gap: 1rem;
}
.gap-6 {
  gap: 1.5rem;
}
.gap-8 {
  gap: 2rem;
}
.gap-12 {
  gap: 3rem;
}
.space-x-2>:not([hidden])~:not([hidden]) {
  --tw-space-x-reverse: 0;
  margin-left: .5rem;
  margin-left: calc(.5rem*(1 - var(--tw-space-x-reverse)));
  margin-right: 0;
  margin-right: calc(.5rem*var(--tw-space-x-reverse));
}
.space-x-3>:not([hidden])~:not([hidden]) {
  --tw-space-x-reverse: 0;
  margin-left: .75rem;
  margin-left: calc(.75rem*(1 - var(--tw-space-x-reverse)));
  margin-right: 0;
  margin-right: calc(.75rem*var(--tw-space-x-reverse));
}
.space-x-4>:not([hidden])~:not([hidden]) {
  --tw-space-x-reverse: 0;
  margin-left: 1rem;
  margin-left: calc(1rem*(1 - var(--tw-space-x-reverse)));
  margin-right: 0;
  margin-right: calc(1rem*var(--tw-space-x-reverse));
}
.space-x-5>:not([hidden])~:not([hidden]) {
  --tw-space-x-reverse: 0;
  margin-left: 1.25rem;
  margin-left: calc(1.25rem*(1 - var(--tw-space-x-reverse)));
  margin-right: 0;
  margin-right: calc(1.25rem*var(--tw-space-x-reverse));
}
.space-x-6>:not([hidden])~:not([hidden]) {
  --tw-space-x-reverse: 0;
  margin-left: 1.5rem;
  margin-left: calc(1.5rem*(1 - var(--tw-space-x-reverse)));
  margin-right: 0;
  margin-right: calc(1.5rem*var(--tw-space-x-reverse));
}
.space-y-2>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-bottom: 0;
  margin-bottom: calc(.5rem*var(--tw-space-y-reverse));
  margin-top: .5rem;
  margin-top: calc(.5rem*(1 - var(--tw-space-y-reverse)));
}
.space-y-3>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-bottom: 0;
  margin-bottom: calc(.75rem*var(--tw-space-y-reverse));
  margin-top: .75rem;
  margin-top: calc(.75rem*(1 - var(--tw-space-y-reverse)));
}
.space-y-4>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-bottom: 0;
  margin-bottom: calc(1rem*var(--tw-space-y-reverse));
  margin-top: 1rem;
  margin-top: calc(1rem*(1 - var(--tw-space-y-reverse)));
}
.space-y-5>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-bottom: 0;
  margin-bottom: calc(1.25rem*var(--tw-space-y-reverse));
  margin-top: 1.25rem;
  margin-top: calc(1.25rem*(1 - var(--tw-space-y-reverse)));
}
.space-y-6>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-bottom: 0;
  margin-bottom: calc(1.5rem*var(--tw-space-y-reverse));
  margin-top: 1.5rem;
  margin-top: calc(1.5rem*(1 - var(--tw-space-y-reverse)));
}
.space-y-8>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-bottom: 0;
  margin-bottom: calc(2rem*var(--tw-space-y-reverse));
  margin-top: 2rem;
  margin-top: calc(2rem*(1 - var(--tw-space-y-reverse)));
}
.space-y-10>:not([hidden])~:not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-bottom: 0;
  margin-bottom: calc(2.5rem*var(--tw-space-y-reverse));
  margin-top: 2.5rem;
  margin-top: calc(2.5rem*(1 - var(--tw-space-y-reverse)));
}
.divide-y>:not([hidden])~:not([hidden]) {
  --tw-divide-y-reverse: 0;
  border-bottom-width: 0;
  border-bottom-width: calc(1px*var(--tw-divide-y-reverse));
  border-top-width: 1px;
  border-top-width: calc(1px*(1 - var(--tw-divide-y-reverse)));
}
.divide-gray-100>:not([hidden])~:not([hidden]) {
  --tw-divide-opacity: 1;
  border-color: #f1f5f9;
  border-color: rgba(241,245,249,var(--tw-divide-opacity));
}
.divide-gray-200>:not([hidden])~:not([hidden]) {
  --tw-divide-opacity: 1;
  border-color: #e2e8f0;
  border-color: rgba(226,232,240,var(--tw-divide-opacity));
}
.overflow-hidden {
  overflow: hidden;
}
.overflow-x-auto {
  overflow-x: auto;
}
.overflow-y-auto {
  overflow-y: auto;
}
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
}
.truncate, .whitespace-nowrap {
  white-space: nowrap;
}
.whitespace-pre-line {
  white-space: pre-line;
}
.break-words {
  word-wrap: break-word;
}
.rounded {
  border-radius: .25rem;
}
.rounded-md {
  border-radius: .375rem;
}
.rounded-lg {
  border-radius: .5rem;
}
.rounded-xl {
  border-radius: .75rem;
}
.rounded-2xl {
  border-radius: 1rem;
}
.rounded-3xl {
  border-radius: 1.5rem;
}
.rounded-full {
  border-radius: 9999px;
}
.border-2 {
  border-width: 2px;
}
.border {
  border-width: 1px;
}
.border-t {
  border-top-width: 1px;
}
.border-b-2 {
  border-bottom-width: 2px;
}
.border-b {
  border-bottom-width: 1px;
}
.border-l-4 {
  border-left-width: 4px;
}
.border-dashed {
  border-style: dashed;
}
.border-none {
  border-style: none;
}
.border-transparent {
  border-color: transparent;
}
.border-white {
  --tw-border-opacity: 1;
  border-color: #fff;
  border-color: rgba(255,255,255,var(--tw-border-opacity));
}
.border-gray-100 {
  --tw-border-opacity: 1;
  border-color: #f1f5f9;
  border-color: rgba(241,245,249,var(--tw-border-opacity));
}
.border-gray-200 {
  --tw-border-opacity: 1;
  border-color: #e2e8f0;
  border-color: rgba(226,232,240,var(--tw-border-opacity));
}
.border-gray-300 {
  --tw-border-opacity: 1;
  border-color: #cbd5e1;
  border-color: rgba(203,213,225,var(--tw-border-opacity));
}
.border-gray-400 {
  --tw-border-opacity: 1;
  border-color: #94a3b8;
  border-color: rgba(148,163,184,var(--tw-border-opacity));
}
.border-red-200 {
  --tw-border-opacity: 1;
  border-color: #fecaca;
  border-color: rgba(254,202,202,var(--tw-border-opacity));
}
.border-green-100 {
  --tw-border-opacity: 1;
  border-color: #d1fae5;
  border-color: rgba(209,250,229,var(--tw-border-opacity));
}
.border-green-200 {
  --tw-border-opacity: 1;
  border-color: #a7f3d0;
  border-color: rgba(167,243,208,var(--tw-border-opacity));
}
.border-green-500 {
  --tw-border-opacity: 1;
  border-color: #10b981;
  border-color: rgba(16,185,129,var(--tw-border-opacity));
}
.border-blue-100 {
  --tw-border-opacity: 1;
  border-color: #dbeafe;
  border-color: rgba(219,234,254,var(--tw-border-opacity));
}
.border-blue-500 {
  --tw-border-opacity: 1;
  border-color: #3b82f6;
  border-color: rgba(59,130,246,var(--tw-border-opacity));
}
.border-blue-600 {
  --tw-border-opacity: 1;
  border-color: #2563eb;
  border-color: rgba(37,99,235,var(--tw-border-opacity));
}
.border-indigo-100 {
  --tw-border-opacity: 1;
  border-color: #e0e7ff;
  border-color: rgba(224,231,255,var(--tw-border-opacity));
}
.border-indigo-200 {
  --tw-border-opacity: 1;
  border-color: #c7d2fe;
  border-color: rgba(199,210,254,var(--tw-border-opacity));
}
.border-purple-100 {
  --tw-border-opacity: 1;
  border-color: #ede9fe;
  border-color: rgba(237,233,254,var(--tw-border-opacity));
}
.border-purple-500 {
  --tw-border-opacity: 1;
  border-color: #8b5cf6;
  border-color: rgba(139,92,246,var(--tw-border-opacity));
}
.border-pink-100 {
  --tw-border-opacity: 1;
  border-color: #fce7f3;
  border-color: rgba(252,231,243,var(--tw-border-opacity));
}
.hover\:border-red-400:hover {
  --tw-border-opacity: 1;
  border-color: #f87171;
  border-color: rgba(248,113,113,var(--tw-border-opacity));
}
.hover\:border-indigo-200:hover {
  --tw-border-opacity: 1;
  border-color: #c7d2fe;
  border-color: rgba(199,210,254,var(--tw-border-opacity));
}
.hover\:border-indigo-300:hover {
  --tw-border-opacity: 1;
  border-color: #a5b4fc;
  border-color: rgba(165,180,252,var(--tw-border-opacity));
}
.hover\:border-indigo-400:hover {
  --tw-border-opacity: 1;
  border-color: #818cf8;
  border-color: rgba(129,140,248,var(--tw-border-opacity));
}
.hover\:border-pink-200:hover {
  --tw-border-opacity: 1;
  border-color: #fbcfe8;
  border-color: rgba(251,207,232,var(--tw-border-opacity));
}
.focus\:border-indigo-300:focus {
  --tw-border-opacity: 1;
  border-color: #a5b4fc;
  border-color: rgba(165,180,252,var(--tw-border-opacity));
}
.focus\:border-indigo-500:focus {
  --tw-border-opacity: 1;
  border-color: #6366f1;
  border-color: rgba(99,102,241,var(--tw-border-opacity));
}
.bg-transparent {
  background-color: transparent;
}
.bg-black {
  --tw-bg-opacity: 1;
  background-color: #000;
  background-color: rgba(0,0,0,var(--tw-bg-opacity));
}
.bg-white {
  --tw-bg-opacity: 1;
  background-color: #fff;
  background-color: rgba(255,255,255,var(--tw-bg-opacity));
}
.bg-gray-50 {
  --tw-bg-opacity: 1;
  background-color: #f8fafc;
  background-color: rgba(248,250,252,var(--tw-bg-opacity));
}
.bg-gray-100 {
  --tw-bg-opacity: 1;
  background-color: #f1f5f9;
  background-color: rgba(241,245,249,var(--tw-bg-opacity));
}
.bg-gray-200 {
  --tw-bg-opacity: 1;
  background-color: #e2e8f0;
  background-color: rgba(226,232,240,var(--tw-bg-opacity));
}
.bg-gray-300 {
  --tw-bg-opacity: 1;
  background-color: #cbd5e1;
  background-color: rgba(203,213,225,var(--tw-bg-opacity));
}
.bg-gray-500 {
  --tw-bg-opacity: 1;
  background-color: #64748b;
  background-color: rgba(100,116,139,var(--tw-bg-opacity));
}
.bg-gray-700 {
  --tw-bg-opacity: 1;
  background-color: #334155;
  background-color: rgba(51,65,85,var(--tw-bg-opacity));
}
.bg-gray-800 {
  --tw-bg-opacity: 1;
  background-color: #1e293b;
  background-color: rgba(30,41,59,var(--tw-bg-opacity));
}
.bg-gray-900 {
  --tw-bg-opacity: 1;
  background-color: #0f172a;
  background-color: rgba(15,23,42,var(--tw-bg-opacity));
}
.bg-red-50 {
  --tw-bg-opacity: 1;
  background-color: #fef2f2;
  background-color: rgba(254,242,242,var(--tw-bg-opacity));
}
.bg-red-500 {
  --tw-bg-opacity: 1;
  background-color: #ef4444;
  background-color: rgba(239,68,68,var(--tw-bg-opacity));
}
.bg-red-700 {
  --tw-bg-opacity: 1;
  background-color: #b91c1c;
  background-color: rgba(185,28,28,var(--tw-bg-opacity));
}
.bg-green-50 {
  --tw-bg-opacity: 1;
  background-color: #ecfdf5;
  background-color: rgba(236,253,245,var(--tw-bg-opacity));
}
.bg-green-100 {
  --tw-bg-opacity: 1;
  background-color: #d1fae5;
  background-color: rgba(209,250,229,var(--tw-bg-opacity));
}
.bg-green-400 {
  --tw-bg-opacity: 1;
  background-color: #34d399;
  background-color: rgba(52,211,153,var(--tw-bg-opacity));
}
.bg-green-500 {
  --tw-bg-opacity: 1;
  background-color: #10b981;
  background-color: rgba(16,185,129,var(--tw-bg-opacity));
}
.bg-green-700 {
  --tw-bg-opacity: 1;
  background-color: #047857;
  background-color: rgba(4,120,87,var(--tw-bg-opacity));
}
.bg-blue-50 {
  --tw-bg-opacity: 1;
  background-color: #eff6ff;
  background-color: rgba(239,246,255,var(--tw-bg-opacity));
}
.bg-blue-100 {
  --tw-bg-opacity: 1;
  background-color: #dbeafe;
  background-color: rgba(219,234,254,var(--tw-bg-opacity));
}
.bg-blue-500 {
  --tw-bg-opacity: 1;
  background-color: #3b82f6;
  background-color: rgba(59,130,246,var(--tw-bg-opacity));
}
.bg-blue-600 {
  --tw-bg-opacity: 1;
  background-color: #2563eb;
  background-color: rgba(37,99,235,var(--tw-bg-opacity));
}
.bg-indigo-50 {
  --tw-bg-opacity: 1;
  background-color: #eef2ff;
  background-color: rgba(238,242,255,var(--tw-bg-opacity));
}
.bg-indigo-100 {
  --tw-bg-opacity: 1;
  background-color: #e0e7ff;
  background-color: rgba(224,231,255,var(--tw-bg-opacity));
}
.bg-indigo-500 {
  --tw-bg-opacity: 1;
  background-color: #6366f1;
  background-color: rgba(99,102,241,var(--tw-bg-opacity));
}
.bg-indigo-600 {
  --tw-bg-opacity: 1;
  background-color: #4f46e5;
  background-color: rgba(79,70,229,var(--tw-bg-opacity));
}
.bg-purple-50 {
  --tw-bg-opacity: 1;
  background-color: #f5f3ff;
  background-color: rgba(245,243,255,var(--tw-bg-opacity));
}
.bg-purple-100 {
  --tw-bg-opacity: 1;
  background-color: #ede9fe;
  background-color: rgba(237,233,254,var(--tw-bg-opacity));
}
.bg-purple-400 {
  --tw-bg-opacity: 1;
  background-color: #a78bfa;
  background-color: rgba(167,139,250,var(--tw-bg-opacity));
}
.bg-purple-500 {
  --tw-bg-opacity: 1;
  background-color: #8b5cf6;
  background-color: rgba(139,92,246,var(--tw-bg-opacity));
}
.bg-pink-100 {
  --tw-bg-opacity: 1;
  background-color: #fce7f3;
  background-color: rgba(252,231,243,var(--tw-bg-opacity));
}
.bg-pink-500 {
  --tw-bg-opacity: 1;
  background-color: #ec4899;
  background-color: rgba(236,72,153,var(--tw-bg-opacity));
}
.hover\:bg-gray-50:hover {
  --tw-bg-opacity: 1;
  background-color: #f8fafc;
  background-color: rgba(248,250,252,var(--tw-bg-opacity));
}
.hover\:bg-gray-100:hover {
  --tw-bg-opacity: 1;
  background-color: #f1f5f9;
  background-color: rgba(241,245,249,var(--tw-bg-opacity));
}
.hover\:bg-gray-200:hover {
  --tw-bg-opacity: 1;
  background-color: #e2e8f0;
  background-color: rgba(226,232,240,var(--tw-bg-opacity));
}
.hover\:bg-red-50:hover {
  --tw-bg-opacity: 1;
  background-color: #fef2f2;
  background-color: rgba(254,242,242,var(--tw-bg-opacity));
}
.hover\:bg-red-100:hover {
  --tw-bg-opacity: 1;
  background-color: #fee2e2;
  background-color: rgba(254,226,226,var(--tw-bg-opacity));
}
.hover\:bg-red-600:hover {
  --tw-bg-opacity: 1;
  background-color: #dc2626;
  background-color: rgba(220,38,38,var(--tw-bg-opacity));
}
.hover\:bg-red-700:hover {
  --tw-bg-opacity: 1;
  background-color: #b91c1c;
  background-color: rgba(185,28,28,var(--tw-bg-opacity));
}
.hover\:bg-green-600:hover {
  --tw-bg-opacity: 1;
  background-color: #059669;
  background-color: rgba(5,150,105,var(--tw-bg-opacity));
}
.hover\:bg-green-700:hover {
  --tw-bg-opacity: 1;
  background-color: #047857;
  background-color: rgba(4,120,87,var(--tw-bg-opacity));
}
.hover\:bg-blue-700:hover {
  --tw-bg-opacity: 1;
  background-color: #1d4ed8;
  background-color: rgba(29,78,216,var(--tw-bg-opacity));
}
.hover\:bg-indigo-50:hover {
  --tw-bg-opacity: 1;
  background-color: #eef2ff;
  background-color: rgba(238,242,255,var(--tw-bg-opacity));
}
.hover\:bg-indigo-100:hover {
  --tw-bg-opacity: 1;
  background-color: #e0e7ff;
  background-color: rgba(224,231,255,var(--tw-bg-opacity));
}
.hover\:bg-indigo-600:hover {
  --tw-bg-opacity: 1;
  background-color: #4f46e5;
  background-color: rgba(79,70,229,var(--tw-bg-opacity));
}
.hover\:bg-indigo-700:hover {
  --tw-bg-opacity: 1;
  background-color: #4338ca;
  background-color: rgba(67,56,202,var(--tw-bg-opacity));
}
.focus\:bg-indigo-600:focus {
  --tw-bg-opacity: 1;
  background-color: #4f46e5;
  background-color: rgba(79,70,229,var(--tw-bg-opacity));
}
.bg-opacity-50 {
  --tw-bg-opacity: 0.5;
}
.bg-opacity-75 {
  --tw-bg-opacity: 0.75;
}
.bg-gradient-to-tr {
  background-image: linear-gradient(to top right,var(--tw-gradient-stops));
}
.bg-gradient-to-r {
  background-image: linear-gradient(to right,var(--tw-gradient-stops));
}
.bg-gradient-to-br {
  background-image: linear-gradient(to bottom right,var(--tw-gradient-stops));
}
.bg-gradient-to-b {
  background-image: linear-gradient(to bottom,var(--tw-gradient-stops));
}
.from-white {
  --tw-gradient-from: #fff;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,hsla(0,0%,100%,0));
}
.from-gray-50 {
  --tw-gradient-from: #f8fafc;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(248,250,252,0));
}
.from-gray-100 {
  --tw-gradient-from: #f1f5f9;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(241,245,249,0));
}
.from-yellow-500 {
  --tw-gradient-from: #f59e0b;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(245,158,11,0));
}
.from-green-400 {
  --tw-gradient-from: #34d399;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(52,211,153,0));
}
.from-green-500 {
  --tw-gradient-from: #10b981;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(16,185,129,0));
}
.from-blue-400 {
  --tw-gradient-from: #60a5fa;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(96,165,250,0));
}
.from-blue-500 {
  --tw-gradient-from: #3b82f6;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(59,130,246,0));
}
.from-indigo-50 {
  --tw-gradient-from: #eef2ff;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(238,242,255,0));
}
.from-indigo-100 {
  --tw-gradient-from: #e0e7ff;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(224,231,255,0));
}
.from-indigo-500 {
  --tw-gradient-from: #6366f1;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(99,102,241,0));
}
.from-indigo-600 {
  --tw-gradient-from: #4f46e5;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(79,70,229,0));
}
.from-purple-50 {
  --tw-gradient-from: #f5f3ff;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(245,243,255,0));
}
.from-purple-400 {
  --tw-gradient-from: #a78bfa;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(167,139,250,0));
}
.from-purple-500 {
  --tw-gradient-from: #8b5cf6;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(139,92,246,0));
}
.from-pink-50 {
  --tw-gradient-from: #fdf2f8;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(253,242,248,0));
}
.from-pink-100 {
  --tw-gradient-from: #fce7f3;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(252,231,243,0));
}
.from-pink-400 {
  --tw-gradient-from: #f472b6;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(244,114,182,0));
}
.from-pink-500 {
  --tw-gradient-from: #ec4899;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(236,72,153,0));
}
.hover\:from-indigo-700:hover {
  --tw-gradient-from: #4338ca;
  --tw-gradient-stops: var(--tw-gradient-from),var(--tw-gradient-to,rgba(67,56,202,0));
}
.via-white {
  --tw-gradient-stops: var(--tw-gradient-from),#fff,var(--tw-gradient-to,hsla(0,0%,100%,0));
}
.via-indigo-700 {
  --tw-gradient-stops: var(--tw-gradient-from),#4338ca,var(--tw-gradient-to,rgba(67,56,202,0));
}
.via-purple-600 {
  --tw-gradient-stops: var(--tw-gradient-from),#7c3aed,var(--tw-gradient-to,rgba(124,58,237,0));
}
.to-white {
  --tw-gradient-to: #fff;
}
.to-gray-100 {
  --tw-gradient-to: #f1f5f9;
}
.to-gray-200 {
  --tw-gradient-to: #e2e8f0;
}
.to-red-500 {
  --tw-gradient-to: #ef4444;
}
.to-blue-50 {
  --tw-gradient-to: #eff6ff;
}
.to-blue-500 {
  --tw-gradient-to: #3b82f6;
}
.to-indigo-50 {
  --tw-gradient-to: #eef2ff;
}
.to-indigo-200 {
  --tw-gradient-to: #c7d2fe;
}
.to-indigo-500 {
  --tw-gradient-to: #6366f1;
}
.to-indigo-600 {
  --tw-gradient-to: #4f46e5;
}
.to-indigo-700 {
  --tw-gradient-to: #4338ca;
}
.to-purple-50 {
  --tw-gradient-to: #f5f3ff;
}
.to-purple-500 {
  --tw-gradient-to: #8b5cf6;
}
.to-purple-600 {
  --tw-gradient-to: #7c3aed;
}
.to-purple-700 {
  --tw-gradient-to: #6d28d9;
}
.to-pink-50 {
  --tw-gradient-to: #fdf2f8;
}
.to-pink-200 {
  --tw-gradient-to: #fbcfe8;
}
.to-pink-500 {
  --tw-gradient-to: #ec4899;
}
.hover\:to-indigo-800:hover {
  --tw-gradient-to: #3730a3;
}
.hover\:to-purple-700:hover {
  --tw-gradient-to: #6d28d9;
}
.bg-clip-text {
  -webkit-background-clip: text;
  background-clip: text;
}
.object-cover {
  -o-object-fit: cover;
  object-fit: cover;
}
.p-0 {
  padding: 0;
}
.p-1 {
  padding: .25rem;
}
.p-2 {
  padding: .5rem;
}
.p-3 {
  padding: .75rem;
}
.p-4 {
  padding: 1rem;
}
.p-5 {
  padding: 1.25rem;
}
.p-6 {
  padding: 1.5rem;
}
.p-8 {
  padding: 2rem;
}
.p-10 {
  padding: 2.5rem;
}
.p-0\.5 {
  padding: .125rem;
}
.p-1\.5 {
  padding: .375rem;
}
.p-2\.5 {
  padding: .625rem;
}
.px-1 {
  padding-left: .25rem;
  padding-right: .25rem;
}
.px-2 {
  padding-left: .5rem;
  padding-right: .5rem;
}
.px-3 {
  padding-left: .75rem;
  padding-right: .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;
}
.px-7 {
  padding-left: 1.75rem;
  padding-right: 1.75rem;
}
.px-8 {
  padding-left: 2rem;
  padding-right: 2rem;
}
.px-12 {
  padding-left: 3rem;
  padding-right: 3rem;
}
.py-1 {
  padding-bottom: .25rem;
  padding-top: .25rem;
}
.py-2 {
  padding-bottom: .5rem;
  padding-top: .5rem;
}
.py-3 {
  padding-bottom: .75rem;
  padding-top: .75rem;
}
.py-4 {
  padding-bottom: 1rem;
  padding-top: 1rem;
}
.py-5 {
  padding-bottom: 1.25rem;
  padding-top: 1.25rem;
}
.py-6 {
  padding-bottom: 1.5rem;
  padding-top: 1.5rem;
}
.py-8 {
  padding-bottom: 2rem;
  padding-top: 2rem;
}
.py-10 {
  padding-bottom: 2.5rem;
  padding-top: 2.5rem;
}
.py-12 {
  padding-bottom: 3rem;
  padding-top: 3rem;
}
.py-16 {
  padding-bottom: 4rem;
  padding-top: 4rem;
}
.py-20 {
  padding-bottom: 5rem;
  padding-top: 5rem;
}
.py-24 {
  padding-bottom: 6rem;
  padding-top: 6rem;
}
.py-36 {
  padding-bottom: 9rem;
  padding-top: 9rem;
}
.py-1\.5 {
  padding-bottom: .375rem;
  padding-top: .375rem;
}
.py-2\.5 {
  padding-bottom: .625rem;
  padding-top: .625rem;
}
.py-3\.5 {
  padding-bottom: .875rem;
  padding-top: .875rem;
}
.pt-4 {
  padding-top: 1rem;
}
.pt-6 {
  padding-top: 1.5rem;
}
.pt-8 {
  padding-top: 2rem;
}
.pb-2 {
  padding-bottom: .5rem;
}
.pb-16 {
  padding-bottom: 4rem;
}
.pb-24 {
  padding-bottom: 6rem;
}
.pl-6 {
  padding-left: 1.5rem;
}
.text-left {
  text-align: left;
}
.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}
.font-sans {
  font-family: ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif,BlinkMacSystemFont,Helvetica Neue,Arial,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;
}
.text-xs {
  font-size: .75rem;
  line-height: 1rem;
}
.text-sm {
  font-size: .875rem;
  line-height: 1.25rem;
}
.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}
.text-lg {
  font-size: 1.125rem;
}
.text-lg, .text-xl {
  line-height: 1.75rem;
}
.text-xl {
  font-size: 1.25rem;
}
.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-5xl {
  font-size: 3rem;
  line-height: 1;
}
.text-7xl {
  font-size: 4.5rem;
  line-height: 1;
}
.text-9xl {
  font-size: 8rem;
  line-height: 1;
}
.font-medium {
  font-weight: 500;
}
.font-semibold {
  font-weight: 600;
}
.font-bold {
  font-weight: 700;
}
.font-extrabold {
  font-weight: 800;
}
.font-black {
  font-weight: 900;
}
.uppercase {
  text-transform: uppercase;
}
.capitalize {
  text-transform: capitalize;
}
.leading-4 {
  line-height: 1rem;
}
.leading-tight {
  line-height: 1.25;
}
.leading-relaxed {
  line-height: 1.625;
}
.tracking-tight {
  letter-spacing: -.025em;
}
.tracking-wider {
  letter-spacing: .05em;
}
.text-transparent {
  color: transparent;
}
.text-white {
  --tw-text-opacity: 1;
  color: #fff;
  color: rgba(255,255,255,var(--tw-text-opacity));
}
.text-gray-300 {
  --tw-text-opacity: 1;
  color: #cbd5e1;
  color: rgba(203,213,225,var(--tw-text-opacity));
}
.text-gray-400 {
  --tw-text-opacity: 1;
  color: #94a3b8;
  color: rgba(148,163,184,var(--tw-text-opacity));
}
.text-gray-500 {
  --tw-text-opacity: 1;
  color: #64748b;
  color: rgba(100,116,139,var(--tw-text-opacity));
}
.text-gray-600 {
  --tw-text-opacity: 1;
  color: #475569;
  color: rgba(71,85,105,var(--tw-text-opacity));
}
.text-gray-700 {
  --tw-text-opacity: 1;
  color: #334155;
  color: rgba(51,65,85,var(--tw-text-opacity));
}
.text-gray-800 {
  --tw-text-opacity: 1;
  color: #1e293b;
  color: rgba(30,41,59,var(--tw-text-opacity));
}
.text-gray-900 {
  --tw-text-opacity: 1;
  color: #0f172a;
  color: rgba(15,23,42,var(--tw-text-opacity));
}
.text-red-500 {
  --tw-text-opacity: 1;
  color: #ef4444;
  color: rgba(239,68,68,var(--tw-text-opacity));
}
.text-red-600 {
  --tw-text-opacity: 1;
  color: #dc2626;
  color: rgba(220,38,38,var(--tw-text-opacity));
}
.text-green-500 {
  --tw-text-opacity: 1;
  color: #10b981;
  color: rgba(16,185,129,var(--tw-text-opacity));
}
.text-green-600 {
  --tw-text-opacity: 1;
  color: #059669;
  color: rgba(5,150,105,var(--tw-text-opacity));
}
.text-green-800 {
  --tw-text-opacity: 1;
  color: #065f46;
  color: rgba(6,95,70,var(--tw-text-opacity));
}
.text-blue-500 {
  --tw-text-opacity: 1;
  color: #3b82f6;
  color: rgba(59,130,246,var(--tw-text-opacity));
}
.text-blue-600 {
  --tw-text-opacity: 1;
  color: #2563eb;
  color: rgba(37,99,235,var(--tw-text-opacity));
}
.text-blue-800 {
  --tw-text-opacity: 1;
  color: #1d40af;
  color: rgba(30,64,175,var(--tw-text-opacity));
}
.text-indigo-100 {
  --tw-text-opacity: 1;
  color: #e0e7ff;
  color: rgba(224,231,255,var(--tw-text-opacity));
}
.text-indigo-400 {
  --tw-text-opacity: 1;
  color: #818cf8;
  color: rgba(129,140,248,var(--tw-text-opacity));
}
.text-indigo-500 {
  --tw-text-opacity: 1;
  color: #6366f1;
  color: rgba(99,102,241,var(--tw-text-opacity));
}
.text-indigo-600 {
  --tw-text-opacity: 1;
  color: #4f46e5;
  color: rgba(79,70,229,var(--tw-text-opacity));
}
.text-indigo-700 {
  --tw-text-opacity: 1;
  color: #4338ca;
  color: rgba(67,56,202,var(--tw-text-opacity));
}
.text-purple-500 {
  --tw-text-opacity: 1;
  color: #8b5cf6;
  color: rgba(139,92,246,var(--tw-text-opacity));
}
.text-purple-600 {
  --tw-text-opacity: 1;
  color: #7c3aed;
  color: rgba(124,58,237,var(--tw-text-opacity));
}
.text-purple-800 {
  --tw-text-opacity: 1;
  color: #5b21b6;
  color: rgba(91,33,182,var(--tw-text-opacity));
}
.text-pink-600 {
  --tw-text-opacity: 1;
  color: #db2777;
  color: rgba(219,39,119,var(--tw-text-opacity));
}
.text-pink-700 {
  --tw-text-opacity: 1;
  color: #be185d;
  color: rgba(190,24,93,var(--tw-text-opacity));
}
.hover\:text-white:hover {
  --tw-text-opacity: 1;
  color: #fff;
  color: rgba(255,255,255,var(--tw-text-opacity));
}
.hover\:text-gray-500:hover {
  --tw-text-opacity: 1;
  color: #64748b;
  color: rgba(100,116,139,var(--tw-text-opacity));
}
.hover\:text-gray-700:hover {
  --tw-text-opacity: 1;
  color: #334155;
  color: rgba(51,65,85,var(--tw-text-opacity));
}
.hover\:text-gray-900:hover {
  --tw-text-opacity: 1;
  color: #0f172a;
  color: rgba(15,23,42,var(--tw-text-opacity));
}
.hover\:text-red-300:hover {
  --tw-text-opacity: 1;
  color: #fca5a5;
  color: rgba(252,165,165,var(--tw-text-opacity));
}
.hover\:text-red-500:hover {
  --tw-text-opacity: 1;
  color: #ef4444;
  color: rgba(239,68,68,var(--tw-text-opacity));
}
.hover\:text-red-700:hover {
  --tw-text-opacity: 1;
  color: #b91c1c;
  color: rgba(185,28,28,var(--tw-text-opacity));
}
.hover\:text-indigo-500:hover {
  --tw-text-opacity: 1;
  color: #6366f1;
  color: rgba(99,102,241,var(--tw-text-opacity));
}
.hover\:text-indigo-600:hover {
  --tw-text-opacity: 1;
  color: #4f46e5;
  color: rgba(79,70,229,var(--tw-text-opacity));
}
.hover\:text-indigo-700:hover {
  --tw-text-opacity: 1;
  color: #4338ca;
  color: rgba(67,56,202,var(--tw-text-opacity));
}
.hover\:text-indigo-800:hover {
  --tw-text-opacity: 1;
  color: #3730a3;
  color: rgba(55,48,163,var(--tw-text-opacity));
}
.hover\:underline:hover {
  -webkit-text-decoration: underline;
  text-decoration: underline;
}
.placeholder-gray-300::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: #cbd5e1;
  color: rgba(203,213,225,var(--tw-placeholder-opacity));
}
.placeholder-gray-300::placeholder {
  --tw-placeholder-opacity: 1;
  color: #cbd5e1;
  color: rgba(203,213,225,var(--tw-placeholder-opacity));
}
.placeholder-gray-500::-moz-placeholder {
  --tw-placeholder-opacity: 1;
  color: #64748b;
  color: rgba(100,116,139,var(--tw-placeholder-opacity));
}
.placeholder-gray-500::placeholder {
  --tw-placeholder-opacity: 1;
  color: #64748b;
  color: rgba(100,116,139,var(--tw-placeholder-opacity));
}
.opacity-0 {
  opacity: 0;
}
.opacity-10 {
  opacity: .1;
}
.opacity-20 {
  opacity: .2;
}
.opacity-30 {
  opacity: .3;
}
.opacity-40 {
  opacity: .4;
}
.opacity-50 {
  opacity: .5;
}
.opacity-75 {
  opacity: .75;
}
.opacity-90 {
  opacity: .9;
}
.group:hover .group-hover\:opacity-100, .opacity-100 {
  opacity: 1;
}
.hover\:opacity-80:hover {
  opacity: .8;
}
.disabled\:opacity-50:disabled {
  opacity: .5;
}
*, :after, :before {
  --tw-shadow: 0 0 transparent;
}
.shadow-sm {
  --tw-shadow: 0 1px 2px 0 rgba(0,0,0,.05);
  box-shadow: 0 0 transparent,0 0 transparent,0 1px 2px 0 rgba(0,0,0,.05);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.shadow {
  --tw-shadow: 0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06);
  box-shadow: 0 0 transparent,0 0 transparent,0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.shadow-md {
  --tw-shadow: 0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
  box-shadow: 0 0 transparent,0 0 transparent,0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.shadow-lg {
  --tw-shadow: 0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);
  box-shadow: 0 0 transparent,0 0 transparent,0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.shadow-xl {
  --tw-shadow: 0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);
  box-shadow: 0 0 transparent,0 0 transparent,0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.shadow-2xl {
  --tw-shadow: 0 25px 50px -12px rgba(0,0,0,.25);
  box-shadow: 0 0 transparent,0 0 transparent,0 25px 50px -12px rgba(0,0,0,.25);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.hover\:shadow:hover {
  --tw-shadow: 0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06);
  box-shadow: 0 0 transparent,0 0 transparent,0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px 0 rgba(0,0,0,.06);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.hover\:shadow-md:hover {
  --tw-shadow: 0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
  box-shadow: 0 0 transparent,0 0 transparent,0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.hover\:shadow-lg:hover {
  --tw-shadow: 0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);
  box-shadow: 0 0 transparent,0 0 transparent,0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.hover\:shadow-xl:hover {
  --tw-shadow: 0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);
  box-shadow: 0 0 transparent,0 0 transparent,0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,.04);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.focus\:outline-none:focus, .outline-none {
  outline: 2px solid transparent;
  outline-offset: 2px;
}
*, :after, :before {
  --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgba(59,130,246,.5);
  --tw-ring-offset-shadow: 0 0 transparent;
  --tw-ring-shadow: 0 0 transparent;
}
.ring-1 {
  --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);
}
.ring-1, .ring-2 {
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 transparent;
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 transparent);
}
.ring-2 {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
}
.focus\:ring-0: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(var(--tw-ring-offset-width)) var(--tw-ring-color);
}
.focus\:ring-0:focus, .focus\:ring-1:focus {
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 transparent;
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 transparent);
}
.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);
}
.focus\:ring-2:focus {
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
}
.focus\:ring-2:focus, .focus\:ring:focus {
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 transparent;
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 transparent);
}
.focus\:ring: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(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);
}
.ring-black {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgba(0,0,0,var(--tw-ring-opacity));
}
.ring-white {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgba(255,255,255,var(--tw-ring-opacity));
}
.focus\:ring-red-500:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgba(239,68,68,var(--tw-ring-opacity));
}
.focus\:ring-indigo-100:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgba(224,231,255,var(--tw-ring-opacity));
}
.focus\:ring-indigo-500:focus {
  --tw-ring-opacity: 1;
  --tw-ring-color: rgba(99,102,241,var(--tw-ring-opacity));
}
.ring-opacity-5 {
  --tw-ring-opacity: 0.05;
}
.focus\:ring-offset-2:focus {
  --tw-ring-offset-width: 2px;
}
.blur {
  --tw-blur: blur(8px);
}
.blur-2xl {
  --tw-blur: blur(40px);
}
.drop-shadow-sm {
  --tw-drop-shadow: drop-shadow(0 1px 1px rgba(0,0,0,.05));
}
.backdrop-filter {
  --tw-backdrop-blur: var(--tw-empty,/*!*/ /*!*/);
  --tw-backdrop-brightness: var(--tw-empty,/*!*/ /*!*/);
  --tw-backdrop-contrast: var(--tw-empty,/*!*/ /*!*/);
  --tw-backdrop-grayscale: var(--tw-empty,/*!*/ /*!*/);
  --tw-backdrop-hue-rotate: var(--tw-empty,/*!*/ /*!*/);
  --tw-backdrop-invert: var(--tw-empty,/*!*/ /*!*/);
  --tw-backdrop-opacity: var(--tw-empty,/*!*/ /*!*/);
  --tw-backdrop-saturate: var(--tw-empty,/*!*/ /*!*/);
  --tw-backdrop-sepia: var(--tw-empty,/*!*/ /*!*/);
  -webkit-backdrop-filter: ;
  backdrop-filter: ;
  -webkit-backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
  backdrop-filter: var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);
}
.backdrop-blur-sm {
  --tw-backdrop-blur: blur(4px);
}
.backdrop-blur-md {
  --tw-backdrop-blur: blur(12px);
}
.backdrop-blur-lg {
  --tw-backdrop-blur: blur(16px);
}
.backdrop-blur-xl {
  --tw-backdrop-blur: blur(24px);
}
.transition-all {
  transition-duration: .15s;
  transition-property: all;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.transition {
  transition-duration: .15s;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;
  transition-property: background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.transition-colors {
  transition-duration: .15s;
  transition-property: background-color,border-color,color,fill,stroke;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.transition-opacity {
  transition-duration: .15s;
  transition-property: opacity;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.transition-shadow {
  transition-duration: .15s;
  transition-property: box-shadow;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.transition-transform {
  transition-duration: .15s;
  transition-property: transform;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.duration-75 {
  transition-duration: 75ms;
}
.duration-100 {
  transition-duration: .1s;
}
.duration-150 {
  transition-duration: .15s;
}
.duration-200 {
  transition-duration: .2s;
}
.duration-300 {
  transition-duration: .3s;
}
.ease-in {
  transition-timing-function: cubic-bezier(.4,0,1,1);
}
.ease-out {
  transition-timing-function: cubic-bezier(0,0,.2,1);
}
.ease-in-out {
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
body, html {
  overscroll-behavior-y: none;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}
:root {
  --vh: 1vh;
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}
.phx-no-feedback .invalid-feedback, .phx-no-feedback.invalid-feedback {
  display: none;
}
.network-container {
  margin-left: auto;
  margin-right: auto;
  max-width: 42rem;
}
.network-header {
  margin-bottom: 2rem;
  text-align: center;
}
.network-header h1 {
  font-size: 1.875rem;
  font-weight: 700;
  line-height: 2.25rem;
  margin-bottom: .5rem;
  --tw-text-opacity: 1;
  color: #0f172a;
  color: rgba(15,23,42,var(--tw-text-opacity));
}
.network-header p {
  font-size: 1.125rem;
  line-height: 1.75rem;
  --tw-text-opacity: 1;
  color: #475569;
  color: rgba(71,85,105,var(--tw-text-opacity));
}
.sync-contacts-button {
  overflow: hidden;
  position: relative;
}
.sync-contacts-button:before {
  content: "";
}
.fixed.sync-contacts-button:before {
  transform: translateZ(0);
}
@media (max-width:640px) {
  .fixed.sync-contacts-button:before .max-w-lg {
    border-radius: 0;
    height: 100%;
    margin: 0;
    max-height: calc(100vh - 60px);
  }
  .fixed.sync-contacts-button:before .overflow-y-auto {
    -webkit-overflow-scrolling: touch;
  }
  .fixed.sync-contacts-button:before .items-center {
    align-items: flex-end;
    padding-bottom: 0;
  }
}
@media (max-width:768px) {
  .fixed.sync-contacts-button:before .max-w-lg {
    margin: 1rem;
    width: calc(100% - 2rem);
  }
  .fixed.sync-contacts-button:before .items-center {
    align-items: center;
    padding: 1rem;
  }
}
@media (max-width:640px) {
  .fixed.sync-contacts-button:before .max-w-lg {
    border-radius: 1rem;
    display: flex;
    flex-direction: column;
    margin: 1rem;
    max-height: calc(90vh - env(safe-area-inset-bottom));
    overflow: hidden;
    width: calc(100% - 2rem);
  }
  .fixed.sync-contacts-button:before .overflow-y-auto {
    flex: 1;
    height: auto;
    max-height: calc(100vh - 60px - env(safe-area-inset-bottom));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .fixed.sync-contacts-button:before .items-end {
    padding-bottom: env(safe-area-inset-bottom);
  }
}
@media (max-width:768px) {
  .fixed.sync-contacts-button:before {
    bottom: 0;
    height: auto;
    left: 0;
    position: fixed;
    right: 0;
    top: 64px;
  }
}
.sync-contacts-button:before {
  bottom: 0;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  --tw-bg-opacity: 1;
  background-color: #fff;
  background-color: rgba(255,255,255,var(--tw-bg-opacity));
  opacity: 0;
  transition-duration: .15s;
  transition-duration: .2s;
  transition-property: opacity;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.sync-contacts-button:hover:before {
  opacity: .1;
}
@media (max-width:640px) {
  .flex.items-center.justify-between.network-card {
    margin: .5rem 0;
    padding: 1rem;
  }
}
.network-card {
  border-radius: .5rem;
  margin-bottom: .75rem;
  --tw-bg-opacity: 1;
  background-color: #fff;
  background-color: rgba(255,255,255,var(--tw-bg-opacity));
  padding: 1rem;
  --tw-shadow: 0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
  box-shadow: 0 0 transparent,0 0 transparent,0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.network-card:hover {
  --tw-shadow: 0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);
  box-shadow: 0 0 transparent,0 0 transparent,0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -2px rgba(0,0,0,.05);
  box-shadow: var(--tw-ring-offset-shadow,0 0 transparent),var(--tw-ring-shadow,0 0 transparent),var(--tw-shadow);
}
.network-card {
  transition-duration: .15s;
  transition-duration: .2s;
  transition-property: box-shadow;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
.network-button {
  border-radius: .375rem;
  font-weight: 500;
  padding: .5rem 1rem;
  transition-duration: .15s;
  transition-duration: .2s;
  transition-property: background-color,border-color,color,fill,stroke;
  transition-timing-function: cubic-bezier(.4,0,.2,1);
}
@media (max-width:640px) {
  .flex.items-center.justify-between.contact-sync-section {
    margin: .5rem 0;
    padding: 1rem;
  }
}
.contact-sync-section {
  border-radius: .5rem;
  --tw-bg-opacity: 1;
  background-color: #f8fafc;
  background-color: rgba(248,250,252,var(--tw-bg-opacity));
  padding: 1rem;
}
@media (max-width:768px) {
  .desktop-only {
    display: none !important;
  }
  .mobile-only {
    display: inline !important;
  }
}
@media (min-width:769px) {
  .mobile-only {
    display: none !important;
  }
  .desktop-only {
    display: inline !important;
  }
}
.contact-row input {
  border-radius: .375rem;
  --tw-border-opacity: 1;
  border-color: #cbd5e1;
  border-color: rgba(203,213,225,var(--tw-border-opacity));
}
.contact-row input:focus {
  --tw-border-opacity: 1;
  border-color: #3b82f6;
  border-color: rgba(59,130,246,var(--tw-border-opacity));
  outline: 2px solid transparent;
  outline-offset: 2px;
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 transparent;
  box-shadow: var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 transparent);
  --tw-ring-opacity: 1;
  --tw-ring-color: rgba(59,130,246,var(--tw-ring-opacity));
}
@media (min-width:640px) {
  .sm\:order-none {
    order: 0;
  }
  .sm\:mx-0 {
    margin-left: 0;
    margin-right: 0;
  }
  .sm\:mt-0 {
    margin-top: 0;
  }
  .sm\:ml-3 {
    margin-left: .75rem;
  }
  .sm\:inline {
    display: inline;
  }
  .sm\:flex {
    display: flex;
  }
  .sm\:inline-flex {
    display: inline-flex;
  }
  .sm\:h-5 {
    height: 1.25rem;
  }
  .sm\:h-32 {
    height: 8rem;
  }
  .sm\:w-5 {
    width: 1.25rem;
  }
  .sm\:w-32 {
    width: 8rem;
  }
  .sm\:w-auto {
    width: auto;
  }
  .sm\:max-w-lg {
    max-width: 32rem;
  }
  .sm\:max-w-xl {
    max-width: 36rem;
  }
  .sm\:flex-none {
    flex: none;
  }
  .sm\:flex-shrink-0 {
    flex-shrink: 0;
  }
  .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-start {
    justify-content: flex-start;
  }
  .sm\:gap-2 {
    gap: .5rem;
  }
  .sm\:gap-8 {
    gap: 2rem;
  }
  .sm\:space-x-4>:not([hidden])~:not([hidden]) {
    --tw-space-x-reverse: 0;
    margin-left: 1rem;
    margin-left: calc(1rem*(1 - var(--tw-space-x-reverse)));
    margin-right: 0;
    margin-right: calc(1rem*var(--tw-space-x-reverse));
  }
  .sm\:space-y-0>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-bottom: 0;
    margin-bottom: calc(0px*var(--tw-space-y-reverse));
    margin-top: 0;
    margin-top: calc(0px*(1 - var(--tw-space-y-reverse)));
  }
  .sm\:p-1 {
    padding: .25rem;
  }
  .sm\:p-2 {
    padding: .5rem;
  }
  .sm\:p-8 {
    padding: 2rem;
  }
  .sm\:p-2\.5 {
    padding: .625rem;
  }
  .sm\:px-3 {
    padding-left: .75rem;
    padding-right: .75rem;
  }
  .sm\:px-4 {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .sm\:px-6 {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
  .sm\:px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
  }
  .sm\:py-1 {
    padding-bottom: .25rem;
    padding-top: .25rem;
  }
  .sm\:py-1\.5 {
    padding-bottom: .375rem;
    padding-top: .375rem;
  }
  .sm\:pb-0 {
    padding-bottom: 0;
  }
  .sm\:text-sm {
    font-size: .875rem;
    line-height: 1.25rem;
  }
  .sm\:text-base {
    font-size: 1rem;
    line-height: 1.5rem;
  }
  .sm\:text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
  .sm\:text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
  }
  .sm\:text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }
  .sm\:text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }
  .sm\:text-6xl {
    font-size: 3.75rem;
    line-height: 1;
  }
}
@media (min-width:768px) {
  .md\:order-1 {
    order: 1;
  }
  .md\:order-2 {
    order: 2;
  }
  .md\:order-last {
    order: 9999;
  }
  .md\:mx-auto {
    margin-left: auto;
    margin-right: auto;
  }
  .md\:my-16 {
    margin-bottom: 4rem;
    margin-top: 4rem;
  }
  .md\:mt-0 {
    margin-top: 0;
  }
  .md\:mt-5 {
    margin-top: 1.25rem;
  }
  .md\:mb-6 {
    margin-bottom: 1.5rem;
  }
  .md\:mb-8 {
    margin-bottom: 2rem;
  }
  .md\:mb-16 {
    margin-bottom: 4rem;
  }
  .md\:block {
    display: block;
  }
  .md\:flex {
    display: flex;
  }
  .md\:hidden {
    display: none;
  }
  .md\:h-16 {
    height: 4rem;
  }
  .md\:w-1\/3 {
    width: 33.333333%;
  }
  .md\:w-2\/3 {
    width: 66.666667%;
  }
  .md\:max-w-xs {
    max-width: 20rem;
  }
  .md\:max-w-3xl {
    max-width: 48rem;
  }
  .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\:flex-row {
    flex-direction: row;
  }
  .md\:items-center {
    align-items: center;
  }
  .md\:justify-start {
    justify-content: flex-start;
  }
  .md\:justify-between {
    justify-content: space-between;
  }
  .md\:gap-3 {
    gap: .75rem;
  }
  .md\:gap-16 {
    gap: 4rem;
  }
  .md\:space-x-4>:not([hidden])~:not([hidden]) {
    --tw-space-x-reverse: 0;
    margin-left: 1rem;
    margin-left: calc(1rem*(1 - var(--tw-space-x-reverse)));
    margin-right: 0;
    margin-right: calc(1rem*var(--tw-space-x-reverse));
  }
  .md\:space-y-0>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-bottom: 0;
    margin-bottom: calc(0px*var(--tw-space-y-reverse));
    margin-top: 0;
    margin-top: calc(0px*(1 - var(--tw-space-y-reverse)));
  }
  .md\:space-y-8>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-bottom: 0;
    margin-bottom: calc(2rem*var(--tw-space-y-reverse));
    margin-top: 2rem;
    margin-top: calc(2rem*(1 - var(--tw-space-y-reverse)));
  }
  .md\:space-y-10>:not([hidden])~:not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-bottom: 0;
    margin-bottom: calc(2.5rem*var(--tw-space-y-reverse));
    margin-top: 2.5rem;
    margin-top: calc(2.5rem*(1 - var(--tw-space-y-reverse)));
  }
  .md\:p-4 {
    padding: 1rem;
  }
  .md\:p-8 {
    padding: 2rem;
  }
  .md\:px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
  }
  .md\:py-4 {
    padding-bottom: 1rem;
    padding-top: 1rem;
  }
  .md\:py-12 {
    padding-bottom: 3rem;
    padding-top: 3rem;
  }
  .md\:py-20 {
    padding-bottom: 5rem;
    padding-top: 5rem;
  }
  .md\:py-24 {
    padding-bottom: 6rem;
    padding-top: 6rem;
  }
  .md\:pb-0 {
    padding-bottom: 0;
  }
  .md\:text-left {
    text-align: left;
  }
  .md\:text-base {
    font-size: 1rem;
    line-height: 1.5rem;
  }
  .md\:text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
  }
  .md\:text-xl {
    font-size: 1.25rem;
    line-height: 1.75rem;
  }
  .md\:text-2xl {
    font-size: 1.5rem;
    line-height: 2rem;
  }
  .md\:text-3xl {
    font-size: 1.875rem;
    line-height: 2.25rem;
  }
  .md\:text-4xl {
    font-size: 2.25rem;
    line-height: 2.5rem;
  }
  .md\:text-5xl {
    font-size: 3rem;
    line-height: 1;
  }
  .md\:text-7xl {
    font-size: 4.5rem;
    line-height: 1;
  }
}
@media (min-width:1024px) {
  .lg\:block {
    display: block;
  }
  .lg\:grid-cols-3 {
    grid-template-columns: repeat(3,minmax(0,1fr));
  }
  .lg\:grid-cols-4 {
    grid-template-columns: repeat(4,minmax(0,1fr));
  }
  .lg\:px-8 {
    padding-left: 2rem;
    padding-right: 2rem;
  }
  .lg\:px-12 {
    padding-left: 3rem;
    padding-right: 3rem;
  }
  .lg\:text-6xl {
    font-size: 3.75rem;
    line-height: 1;
  }
}
#nprogress {
  pointer-events: none;
}
#nprogress .bar {
  background: #29d;
  height: 2px;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 1031;
}
#nprogress .peg {
  box-shadow: 0 0 10px #29d,0 0 5px #29d;
  display: block;
  height: 100%;
  opacity: 1;
  position: absolute;
  right: 0;
  transform: rotate(3deg) translateY(-4px);
  width: 100px;
}
#nprogress .spinner {
  display: block;
  position: fixed;
  right: 15px;
  top: 15px;
  z-index: 1031;
}
#nprogress .spinner-icon {
  animation: nprogress-spinner .4s linear infinite;
  border-color: #29d transparent transparent #29d;
  border-radius: 50%;
  border-style: solid;
  border-width: 2px;
  box-sizing: border-box;
  height: 18px;
  width: 18px;
}
.nprogress-custom-parent {
  overflow: hidden;
  position: relative;
}
.nprogress-custom-parent #nprogress .bar, .nprogress-custom-parent #nprogress .spinner {
  position: absolute;
}
@keyframes nprogress-spinner {
  0% {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(1turn);
  }
}
.share-modal-overlay {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(8px);
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 60;
  animation: shareModalFadeIn 0.2s ease;
  padding: 16px;
  box-sizing: border-box;
  transform: none !important;
}
.share-modal-content {
  background: var(--manifest-card, #fff);
  border-radius: var(--radius-xl, 20px);
  max-width: 400px;
  width: 100%;
  max-height: calc(100dvh - 64px);
  overflow-y: auto;
  box-shadow: var(--manifest-shadow-lg, 0 20px 60px rgba(0, 0, 0, 0.3));
  animation: shareModalSlideUp 0.3s ease;
  margin: auto;
}
.share-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 24px 24px 16px;
  border-bottom: 1px solid var(--manifest-border, #E8E4E0);
}
.share-modal-title {
  font-size: 24px;
  font-weight: bold;
  color: var(--manifest-text, #2D2926);
  margin: 0;
}
.close-button {
  background: none;
  border: none;
  font-size: 32px;
  color: var(--manifest-text-muted, #6B6560);
  cursor: pointer;
  padding: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm, 6px);
  transition: all 0.2s;
}
.close-button:hover {
  background: #f3f4f6;
  color: var(--manifest-text, #2D2926);
}
.share-modal-body {
  padding: 24px;
}
.share-cta {
  font-size: 16px;
  color: var(--manifest-text-muted, #6B6560);
  margin: 0 0 20px 0;
  text-align: center;
}
.share-stats {
  display: flex;
  gap: 16px;
  margin-bottom: 24px;
  padding: 16px;
  background: var(--manifest-bg, #FDFCFB);
  border-radius: var(--radius-md, 10px);
}
.stat-item {
  flex: 1;
  text-align: center;
}
.stat-label {
  display: block;
  font-size: 12px;
  color: var(--manifest-text-muted, #6B6560);
  margin-bottom: 4px;
}
.stat-value {
  display: block;
  font-size: 18px;
  font-weight: bold;
  color: var(--manifest-text, #2D2926);
}
.share-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 20px;
}
.share-button-primary {
  background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
  color: white;
  border: none;
  border-radius: var(--radius-lg, 14px);
  padding: 18px 24px;
  font-size: 18px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  transition: all 0.2s;
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
}
.share-button-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(99, 102, 241, 0.4);
}
.share-button-primary:active {
  transform: translateY(0);
}
.share-button-secondary {
  background: var(--manifest-card, #fff);
  color: var(--manifest-primary);
  border: 1.5px solid var(--manifest-border, #E8E4E0);
  border-radius: var(--radius-md, 10px);
  padding: 14px 20px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all 0.2s;
}
.share-button-secondary:hover {
  border-color: var(--manifest-primary);
  background: var(--manifest-bg, #FDFCFB);
}
.share-icon {
  font-size: 20px;
}
.share-link-display {
  margin-bottom: 20px;
}
.share-link-input {
  width: 100%;
  padding: 12px;
  border: 1.5px solid var(--manifest-border, #E8E4E0);
  border-radius: var(--radius-sm, 6px);
  font-size: 14px;
  color: var(--manifest-text-muted, #6B6560);
  background: var(--manifest-bg, #FDFCFB);
  text-align: center;
}
.social-share-buttons {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
}
.social-share-btn {
  flex: 1;
  padding: 12px;
  border-radius: var(--radius-md, 10px);
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  text-align: center;
  transition: all 0.2s;
}
.social-share-btn.twitter {
  background: #000;
  color: white;
}
.social-share-btn.twitter:hover {
  background: #1a1a1a;
}
.social-share-btn.whatsapp {
  background: #25d366;
  color: white;
}
.social-share-btn.whatsapp:hover {
  background: #1fb855;
}
.view-chat-button {
  width: 100%;
  background: transparent;
  border: none;
  color: var(--manifest-text-muted, #6B6560);
  padding: 12px;
  font-size: 14px;
  cursor: pointer;
  transition: color 0.2s;
}
.view-chat-button:hover {
  color: #4f46e5;
}
@keyframes shareModalFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes shareModalSlideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (max-width: 640px) {
  .share-modal-overlay {
    padding: 12px;
  }
  .share-modal-content {
    max-width: 100%;
    width: 100%;
    border-radius: var(--radius-lg, 14px);
    max-height: calc(100vh - 48px);
  }
  .share-modal-header {
    padding: 16px 16px 12px;
  }
  .share-modal-title {
    font-size: 20px;
  }
  .share-modal-body {
    padding: 16px;
  }
  .share-cta {
    font-size: 14px;
    margin-bottom: 16px;
  }
  .share-stats {
    flex-direction: row;
    gap: 8px;
    padding: 12px;
    margin-bottom: 16px;
  }
  .stat-label {
    font-size: 11px;
  }
  .stat-value {
    font-size: 14px;
  }
  .share-button-primary {
    padding: 14px 16px;
    font-size: 15px;
    border-radius: var(--radius-md, 10px);
  }
  .share-button-secondary {
    padding: 10px 14px;
    font-size: 14px;
    border-radius: var(--radius-md, 10px);
  }
  .share-link-display {
    margin-bottom: 16px;
  }
  .share-link-input {
    padding: 10px;
    font-size: 12px;
  }
  .social-share-buttons {
    gap: 8px;
    margin-bottom: 16px;
  }
  .social-share-btn {
    padding: 10px;
    font-size: 13px;
    border-radius: var(--radius-md, 10px);
  }
  .view-chat-button {
    padding: 10px;
    font-size: 13px;
  }
}
.post-aged {
  opacity: 0.55;
  transition: opacity 0.2s ease;
}
.post-aged:hover {
  opacity: 0.85;
}
@media (min-width: 768px) {
  #sidebar-panel {
    transition: width 0.2s ease-out;
  }
  #sidebar-panel.sidebar-collapsed {
    width: 60px;
  }
  #sidebar-panel.sidebar-collapsed .sidebar-expanded-only {
    display: none;
  }
  #sidebar-panel.sidebar-collapsed .sidebar-collapsed-only {
    display: block;
  }
  #sidebar-panel.sidebar-collapsed .sidebar-scroll {
    overflow-x: hidden;
  }
  #sidebar-panel.sidebar-collapsed > div:first-child {
    justify-content: center;
    padding-left: 0;
    padding-right: 0;
  }
}
.sidebar-tooltip {
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  margin-left: 8px;
  padding: 4px 10px;
  background: var(--manifest-cat-dark);
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  border-radius: 6px;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.15s ease;
  z-index: 100;
}
.sidebar-tooltip::before {
  content: "";
  position: absolute;
  right: 100%;
  top: 50%;
  transform: translateY(-50%);
  border: 4px solid transparent;
  border-right-color: var(--manifest-cat-dark);
}
.group:hover > .sidebar-tooltip {
  opacity: 1;
}
@keyframes msg-in {
  from {
    opacity: 0;
    transform: translateY(16px) scale(0.97);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes hero-up {
  from {
    opacity: 0;
    transform: translateY(24px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes pulse-dot {
  0%, 80%, 100% {
    opacity: 0.3;
    transform: scale(0.85);
  }
  40% {
    opacity: 1;
    transform: scale(1.1);
  }
}
@keyframes cursor-blink {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
}
@keyframes badge-pulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(79, 70, 229, 0.3);
  }
  50% {
    box-shadow: 0 0 0 6px rgba(79, 70, 229, 0);
  }
}
@keyframes ticker-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.msg-enter {
  animation: msg-in 0.4s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.hero-enter {
  animation: hero-up 0.7s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.hero-enter-d1 {
  animation: hero-up 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.1s both;
}
.hero-enter-d2 {
  animation: hero-up 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.2s both;
}
.hero-enter-d3 {
  animation: hero-up 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.35s both;
}
.hero-enter-d4 {
  animation: hero-up 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.5s both;
}
.thinking-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--manifest-border-strong);
  animation: pulse-dot 1.4s ease-in-out infinite;
}
.thinking-dot:nth-child(2) {
  animation-delay: 0.2s;
}
.thinking-dot:nth-child(3) {
  animation-delay: 0.4s;
}
.stream-cursor {
  display: inline-block;
  width: 2px;
  height: 1em;
  background: var(--manifest-primary);
  margin-left: 2px;
  border-radius: 1px;
  vertical-align: text-bottom;
  animation: cursor-blink 1s step-end infinite;
}
.mani-avatar {
  background: var(--manifest-primary-light);
}
.mani-chip {
  background: var(--manifest-bg);
  border: 1px solid transparent;
  transition: all 0.15s ease;
}
.mani-chip:hover {
  border-color: var(--manifest-border);
}
.mani-input-field {
  transition: all 0.15s ease;
}
.mani-input-field:focus {
  border-color: var(--manifest-border) !important;
  background: var(--manifest-card) !important;
}
.mani-user-bubble {
  background: var(--manifest-text);
  color: white;
  overflow-wrap: break-word;
  word-break: break-word;
}
.mani-assistant-text {
  color: var(--manifest-text);
  overflow-wrap: break-word;
  word-break: break-word;
}
.landing-input {
  transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}
.landing-input:focus {
  border-color: var(--manifest-border) !important;
  background: var(--manifest-card) !important;
  box-shadow: var(--manifest-shadow-glow), var(--manifest-shadow-sm);
}
.chip-btn {
  transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
  position: relative;
  overflow: hidden;
  background: var(--manifest-bg);
  border: 1px solid var(--manifest-border);
}
.chip-btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(79,70,229,0.04), rgba(79,70,229,0));
  opacity: 0;
  transition: opacity 0.2s;
  pointer-events: none;
}
.chip-btn:hover::after {
  opacity: 1;
}
.chip-btn:hover {
  border-color: var(--manifest-border-strong) !important;
  transform: translateY(-2px);
  box-shadow: var(--manifest-shadow);
}
.chip-btn:active {
  transform: translateY(0);
  box-shadow: none;
}
.ticker-active {
  animation: ticker-in 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.signup-card {
  background: linear-gradient(135deg, var(--manifest-bg) 0%, var(--manifest-secondary-light) 100%);
  border: 1px solid var(--manifest-border);
}
.send-btn {
  transition: all 0.2s cubic-bezier(0.16, 1, 0.3, 1);
}
.send-btn:not(:disabled):hover {
  transform: scale(1.05);
  box-shadow: var(--manifest-shadow);
}
.send-btn:not(:disabled):active {
  transform: scale(0.95);
}
.nav-signin {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  background: var(--manifest-text);
  color: white;
  border-radius: var(--radius-md);
  font-size: var(--text-caption);
  font-weight: 500;
  text-decoration: none;
  letter-spacing: -0.01em;
  transition: all var(--transition-base);
}
.nav-signin:hover {
  opacity: 0.85;
}
.retry-btn {
  background: var(--manifest-bg);
  color: var(--manifest-text);
  border: 1px solid var(--manifest-border);
  transition: all 0.15s;
}
.retry-btn:hover {
  background: var(--manifest-border);
  border-color: var(--manifest-border-strong);
}
.signup-cta {
  background: var(--manifest-primary);
  color: white;
  text-decoration: none;
  box-shadow: 0 2px 8px rgba(79,70,229,0.25);
  transition: all var(--transition-base);
}
.signup-cta:hover {
  background: var(--manifest-primary-dark);
  box-shadow: 0 4px 12px rgba(79,70,229,0.3);
}
.dismiss-btn {
  color: var(--manifest-text-muted);
  background: none;
  border: none;
  transition: color 0.15s;
}
.dismiss-btn:hover {
  color: var(--manifest-text);
}
.assistant-content p {
  margin: 4px 0;
}
.assistant-content ul, .assistant-content ol {
  margin: 8px 0;
}
.assistant-content li {
  margin: 2px 0;
}
.assistant-content strong {
  color: var(--manifest-text);
}
.assistant-content a {
  color: var(--manifest-primary);
}
.assistant-content a:hover {
  text-decoration: none;
}
.guest-landing-nav {
  position: sticky;
  top: 0;
  z-index: 40;
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--manifest-border);
}
.guest-chat-footer {
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--manifest-border);
}
.auth-chat-footer {
  background: var(--manifest-card);
}
.send-btn-active {
  background: var(--manifest-primary);
}
.send-btn-inactive {
  background: var(--manifest-border);
}
.landing-hero-badge {
  background: var(--manifest-primary-light);
  color: var(--manifest-primary);
  letter-spacing: 0.04em;
  animation: badge-pulse 3s ease infinite;
}
.landing-stat-dot {
  background: var(--manifest-border-strong);
}
.landing-ticker-card {
  background: var(--manifest-bg);
  border: 1px solid var(--manifest-border);
}
.landing-category-badge {
  background: var(--manifest-primary-light);
  color: var(--manifest-primary);
}
.hero-gradient-text {
  background: linear-gradient(135deg, var(--manifest-primary), var(--manifest-secondary));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.nav-link-item {
  transition: background 0.15s;
  text-decoration: none;
}
.nav-link-item:hover {
  background: var(--manifest-bg);
}
.nav-cta-btn {
  background: var(--manifest-primary);
  padding: 8px 20px;
  text-decoration: none;
  transition: background 0.15s;
}
.nav-cta-btn:hover {
  background: var(--manifest-primary-dark) !important;
}
.session-link {
  transition: color 0.15s;
  text-decoration: none;
}
.session-link:hover {
  color: var(--manifest-text) !important;
}
.auth-card-enter {
  animation: manifest-page-fade-in 0.5s cubic-bezier(0.16, 1, 0.3, 1) both;
}
.auth-trust-signal {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  font-size: var(--text-overline);
  color: var(--manifest-text-muted);
  margin-top: var(--space-lg);
}
.auth-brand-glow {
  position: absolute;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79, 70, 229, 0.06) 0%, transparent 70%);
  top: -80px;
  right: -60px;
  pointer-events: none;
}
:focus-visible {
  outline: 2px solid var(--manifest-primary);
  outline-offset: 2px;
}
input:focus-visible, textarea:focus-visible, select:focus-visible {
  outline: none;
  border-color: var(--manifest-primary);
  box-shadow: var(--manifest-shadow-glow);
}
a:focus-visible {
  border-radius: var(--radius-sm);
}
button:focus-visible {
  border-radius: var(--radius-sm);
}
.idx-nav-btn {
  transition: opacity 0.15s;
}
.idx-nav-btn:hover {
  opacity: 0.85;
}
.idx-chip {
  transition: all 0.15s ease;
  border: 1px solid transparent;
}
.idx-chip:hover {
  border-color: var(--manifest-border);
}
.idx-cta {
  transition: opacity 0.15s;
}
.idx-cta:hover {
  opacity: 0.85;
}
.idx-link {
  transition: color 0.15s;
}
.idx-link:hover {
  color: var(--manifest-text) !important;
}
@media (min-width: 768px) {
  [data-sidebar-collapsed] #sidebar-panel {
    width: 60px !important;
  }
  [data-sidebar-collapsed] #sidebar-panel .sidebar-expanded-only {
    display: none !important;
  }
  [data-sidebar-collapsed] #sidebar-panel .sidebar-collapsed-only {
    display: block !important;
  }
  [data-sidebar-collapsed] #main-content-area {
    margin-left: 60px !important;
  }
  [data-sidebar-collapsed] #sidebar-panel > div:first-child {
    justify-content: center;
    padding-left: 0;
    padding-right: 0;
  }
}
.share-post-container {
  max-width: 700px;
  margin: 0 auto;
  padding: 20px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.post-card {
  background: var(--manifest-card);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  overflow: hidden;
  width: 100%;
  margin-bottom: 20px;
}
.post-header {
  padding: 20px;
  border-bottom: 1px solid var(--manifest-border);
  display: flex;
  align-items: center;
  gap: 12px;
}
.user-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--manifest-primary) 0%, var(--manifest-accent) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: 600;
  font-size: 18px;
}
.user-info {
  flex: 1;
}
.user-name {
  font-weight: 600;
  color: var(--manifest-text);
  font-size: 16px;
}
.post-time {
  color: var(--manifest-text-muted);
  font-size: 14px;
}
.post-content-area {
  padding: 24px 20px;
}
.post-title {
  font-size: 24px;
  font-weight: 700;
  color: var(--manifest-text);
  margin-bottom: 12px;
  line-height: 1.3;
}
.post-content {
  font-size: 16px;
  color: var(--manifest-text);
  line-height: 1.6;
  margin-bottom: 16px;
}
.post-image {
  width: 100%;
  max-height: 400px;
  object-fit: cover;
  border-radius: 12px;
  margin-top: 16px;
}
.post-location {
  color: var(--manifest-text-muted);
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
}
.cta-card {
  background: var(--manifest-card);
  border-radius: 16px;
  padding: 32px 24px;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  width: 100%;
}
.cta-title {
  font-size: 22px;
  font-weight: 700;
  color: var(--manifest-text);
  margin-bottom: 12px;
}
.cta-description {
  font-size: 16px;
  color: var(--manifest-text-muted);
  margin-bottom: 24px;
}
.cta-button {
  background: linear-gradient(135deg, var(--manifest-primary) 0%, var(--manifest-accent) 100%);
  color: white;
  padding: 16px 32px;
  border-radius: 12px;
  font-size: 18px;
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
  transition: transform 0.2s, box-shadow 0.2s;
}
.cta-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(79, 70, 229, 0.4);
}
.manifest-badge {
  margin-top: 24px;
  opacity: 0.7;
  font-size: 14px;
  color: white;
}
.share-actions {
  display: flex;
  gap: 12px;
  margin-top: 16px;
  padding: 16px 20px;
  border-top: 1px solid var(--manifest-border);
}
.share-twitter-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: var(--manifest-primary);
  color: white;
  border-radius: 9999px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s, transform 0.2s;
}
.share-twitter-btn:hover {
  background: var(--manifest-primary-dark);
  transform: translateY(-1px);
}
.share-twitter-btn svg {
  width: 18px;
  height: 18px;
}
.social-proof {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--manifest-border);
}
.proof-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  color: var(--manifest-text-muted);
  background: var(--manifest-bg);
  padding: 8px 12px;
  border-radius: 8px;
}
.mani-md-code {
  background: var(--manifest-bg);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 13px;
}
.mani-md-link {
  color: var(--manifest-primary);
  text-decoration: underline;
}
.mani-md-ul {
  margin: 8px 0;
  padding-left: 20px;
  list-style: disc;
}
.mani-md-ol {
  margin: 8px 0;
  padding-left: 20px;
}
.mani-md-h3 {
  font-weight: 600;
  margin: 12px 0 4px;
}
.mani-md-h2 {
  font-weight: 600;
  font-size: 15px;
  margin: 12px 0 4px;
}
.mani-md-h1 {
  font-weight: 700;
  font-size: 16px;
  margin: 12px 0 4px;
}
.mani-md-p {
  margin: 4px 0;
}
@layer base {
  @property --radialprogress {
    syntax: "<percentage>";
    inherits: true;
    initial-value: 0%;
  }
}
@layer base {
  :root {
    scrollbar-color: currentColor #0000;
    @supports (color: color-mix(in lab, red, red)) {
      scrollbar-color: color-mix(in oklch, currentColor 35%, #0000) #0000;
    }
  }
}
@layer base {
  :root:has( .modal-open, .modal[open], .modal:target, .modal-toggle:checked, .drawer:not([class*="drawer-open"]) > .drawer-toggle:checked ) {
    overflow: hidden;
  }
}
@layer base {
  :root, [data-theme] {
    background-color: var(--root-bg, var(--color-base-100));
    color: var(--color-base-content);
  }
}
@layer base {
  :root {
    --fx-noise: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.34' numOctaves='4' stitchTiles='stitch'%3E%3C/feTurbulence%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)' opacity='0.2'%3E%3C/rect%3E%3C/svg%3E");
  }
  .chat {
    --mask-chat: url("data:image/svg+xml,%3csvg width='13' height='13' xmlns='http://www.w3.org/2000/svg'%3e%3cpath fill='black' d='M0 11.5004C0 13.0004 2 13.0004 2 13.0004H12H13V0.00036329L12.5 0C12.5 0 11.977 2.09572 11.8581 2.50033C11.6075 3.35237 10.9149 4.22374 9 5.50036C6 7.50036 0 10.0004 0 11.5004Z'/%3e%3c/svg%3e");
  }
}
@layer base {
  :where( :root:has( .modal-open, .modal[open], .modal:target, .modal-toggle:checked, .drawer:not(.drawer-open) > .drawer-toggle:checked ) ) {
    scrollbar-gutter: stable;
    background-image: linear-gradient(var(--color-base-100), var(--color-base-100));
    --root-bg: var(--color-base-100);
    @supports (color: color-mix(in lab, red, red)) {
      --root-bg: color-mix(in srgb, var(--color-base-100), oklch(0% 0 0) 40%);
    }
  }
}
@keyframes skeleton {
  0% {
    background-position: 150%;
  }
  100% {
    background-position: -50%;
  }
}
@keyframes progress {
  50% {
    background-position-x: -115%;
  }
}
@keyframes radio {
  0% {
    padding: 5px;
  }
  50% {
    padding: 3px;
  }
}
@keyframes dropdown {
  0% {
    opacity: 0;
  }
}
@keyframes rating {
  0%, 40% {
    scale: 1.1;
    filter: brightness(1.05) contrast(1.05);
  }
}
@keyframes toast {
  0% {
    scale: 0.9;
    opacity: 0;
  }
  100% {
    scale: 1;
    opacity: 1;
  }
}
@layer base {
  :where(:root),:root:has(input.theme-controller[value=light]:checked),[data-theme="light"] {
    color-scheme: light;
    --color-base-100: oklch(99% 0.002 90);
    --color-base-200: oklch(97% 0.003 90);
    --color-base-300: oklch(94% 0.004 90);
    --color-base-content: oklch(25% 0.01 50);
    --color-primary: oklch(48% 0.233 277.117);
    --color-primary-content: oklch(96% 0.018 272.314);
    --color-secondary: oklch(50% 0.233 292.717);
    --color-secondary-content: oklch(96% 0.018 272.314);
    --color-accent: oklch(52% 0.25 277.117);
    --color-accent-content: oklch(96% 0.016 277.117);
    --color-neutral: oklch(45% 0.01 50);
    --color-neutral-content: oklch(98% 0.003 90);
    --color-info: oklch(58% 0.158 241.966);
    --color-info-content: oklch(97% 0.013 236.62);
    --color-success: oklch(60% 0.118 184.704);
    --color-success-content: oklch(98% 0.014 180.72);
    --color-warning: oklch(66% 0.179 58.318);
    --color-warning-content: oklch(98% 0.022 95.277);
    --color-error: oklch(58% 0.253 17.585);
    --color-error-content: oklch(96% 0.015 12.422);
    --radius-selector: 0.25rem;
    --radius-field: 0.25rem;
    --radius-box: 0.5rem;
    --size-selector: 0.21875rem;
    --size-field: 0.21875rem;
    --border: 1.5px;
    --depth: 1;
    --noise: 0;
  }
}
@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-space-x-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-divide-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-gradient-position {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-from {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-via {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-to {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-stops {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-via-stops {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-from-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0%;
}
@property --tw-gradient-via-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 50%;
}
@property --tw-gradient-to-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-tracking {
  syntax: "*";
  inherits: false;
}
@property --tw-ordinal {
  syntax: "*";
  inherits: false;
}
@property --tw-slashed-zero {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-figure {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-spacing {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-fraction {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-duration {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
@keyframes ping {
  75%, 100% {
    transform: scale(2);
    opacity: 0;
  }
}
@keyframes pulse {
  50% {
    opacity: 0.5;
  }
}
@keyframes bounce {
  0%, 100% {
    transform: translateY(-25%);
    animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
  }
  50% {
    transform: none;
    animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
  }
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-space-x-reverse: 0;
      --tw-divide-y-reverse: 0;
      --tw-border-style: solid;
      --tw-gradient-position: initial;
      --tw-gradient-from: #0000;
      --tw-gradient-via: #0000;
      --tw-gradient-to: #0000;
      --tw-gradient-stops: initial;
      --tw-gradient-via-stops: initial;
      --tw-gradient-from-position: 0%;
      --tw-gradient-via-position: 50%;
      --tw-gradient-to-position: 100%;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-ordinal: initial;
      --tw-slashed-zero: initial;
      --tw-numeric-figure: initial;
      --tw-numeric-spacing: initial;
      --tw-numeric-fraction: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
      --tw-duration: initial;
      --tw-ease: initial;
    }
  }
}
