/*! tailwindcss v4.1.14 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol',
    'Noto Color Emoji';
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New',
    monospace;
    --color-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-400: oklch(70.4% 0.191 22.216);
    --color-red-500: oklch(63.7% 0.237 25.331);
    --color-red-800: oklch(44.4% 0.177 26.899);
    --color-red-900: oklch(39.6% 0.141 25.723);
    --color-red-950: oklch(25.8% 0.092 26.042);
    --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-400: oklch(75% 0.183 55.934);
    --color-orange-500: oklch(70.5% 0.213 47.604);
    --color-orange-600: oklch(64.6% 0.222 41.116);
    --color-orange-800: oklch(47% 0.157 37.304);
    --color-orange-900: oklch(40.8% 0.123 38.172);
    --color-orange-950: oklch(26.6% 0.079 36.259);
    --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-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-800: oklch(47.3% 0.137 46.201);
    --color-amber-900: oklch(41.4% 0.112 45.904);
    --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-800: oklch(47.6% 0.114 61.907);
    --color-yellow-900: oklch(42.1% 0.095 57.708);
    --color-yellow-950: oklch(28.6% 0.066 53.813);
    --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-800: oklch(44.8% 0.119 151.328);
    --color-green-900: oklch(39.3% 0.095 152.535);
    --color-green-950: oklch(26.6% 0.065 152.934);
    --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-500: oklch(69.6% 0.17 162.48);
    --color-emerald-800: oklch(43.2% 0.095 166.913);
    --color-emerald-900: oklch(37.8% 0.077 168.94);
    --color-emerald-950: oklch(26.2% 0.051 172.552);
    --color-cyan-50: oklch(98.4% 0.019 200.873);
    --color-cyan-100: oklch(95.6% 0.045 203.388);
    --color-cyan-200: oklch(91.7% 0.08 205.041);
    --color-cyan-400: oklch(78.9% 0.154 211.53);
    --color-cyan-500: oklch(71.5% 0.143 215.221);
    --color-cyan-800: oklch(45% 0.085 224.283);
    --color-cyan-900: oklch(39.8% 0.07 227.392);
    --color-cyan-950: oklch(30.2% 0.056 229.695);
    --color-sky-50: oklch(97.7% 0.013 236.62);
    --color-sky-100: oklch(95.1% 0.026 236.824);
    --color-sky-200: oklch(90.1% 0.058 230.902);
    --color-sky-400: oklch(74.6% 0.16 232.661);
    --color-sky-600: oklch(58.8% 0.158 241.966);
    --color-sky-700: oklch(50% 0.134 242.749);
    --color-sky-800: oklch(44.3% 0.11 240.79);
    --color-sky-900: oklch(39.1% 0.09 240.876);
    --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-400: oklch(70.7% 0.165 254.624);
    --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-blue-950: oklch(28.2% 0.091 267.935);
    --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-500: oklch(58.5% 0.233 277.117);
    --color-indigo-800: oklch(39.8% 0.195 277.366);
    --color-indigo-900: oklch(35.9% 0.144 278.697);
    --color-indigo-950: oklch(25.7% 0.09 281.288);
    --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-800: oklch(43.8% 0.218 303.724);
    --color-purple-900: oklch(38.1% 0.176 304.987);
    --color-purple-950: oklch(29.1% 0.149 302.717);
    --color-fuchsia-500: oklch(66.7% 0.295 322.15);
    --color-slate-100: oklch(96.8% 0.007 247.896);
    --color-slate-200: oklch(92.9% 0.013 255.508);
    --color-slate-300: oklch(86.9% 0.022 252.894);
    --color-slate-400: oklch(70.4% 0.04 256.788);
    --color-slate-500: oklch(55.4% 0.046 257.417);
    --color-slate-600: oklch(44.6% 0.043 257.281);
    --color-slate-700: oklch(37.2% 0.044 257.287);
    --color-slate-800: oklch(27.9% 0.041 260.031);
    --color-slate-900: oklch(20.8% 0.042 265.755);
    --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-zinc-700: oklch(37% 0.013 285.805);
    --color-zinc-800: oklch(27.4% 0.006 286.033);
    --color-zinc-900: oklch(21% 0.006 285.885);
    --color-stone-100: oklch(97% 0.001 106.424);
    --color-stone-200: oklch(92.3% 0.003 48.717);
    --color-stone-300: oklch(86.9% 0.005 56.366);
    --color-stone-400: oklch(70.9% 0.01 56.259);
    --color-stone-500: oklch(55.3% 0.013 58.071);
    --color-stone-600: oklch(44.4% 0.011 73.639);
    --color-stone-700: oklch(37.4% 0.01 67.558);
    --color-black: #000;
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --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;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --tracking-wide: 0.025em;
    --leading-relaxed: 1.625;
    --radius-xs: 0.125rem;
    --radius-sm: 0.25rem;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-2xl: 1rem;
    --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);
    --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;
    --blur-sm: 8px;
    --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);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji');
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type='button'], [type='reset'], [type='submit']), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden='until-found'])) {
    display: none !important;
  }
}
@layer utilities {
  .pointer-events-none {
    pointer-events: none;
  }
  .collapse {
    visibility: collapse;
  }
  .visible {
    visibility: visible;
  }
  .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border-width: 0;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .top-2 {
    top: calc(var(--spacing) * 2);
  }
  .top-3 {
    top: calc(var(--spacing) * 3);
  }
  .top-4 {
    top: calc(var(--spacing) * 4);
  }
  .top-\[100vh\] {
    top: 100vh;
  }
  .top-full {
    top: 100%;
  }
  .right-0 {
    right: calc(var(--spacing) * 0);
  }
  .right-2 {
    right: calc(var(--spacing) * 2);
  }
  .right-3 {
    right: calc(var(--spacing) * 3);
  }
  .right-4 {
    right: calc(var(--spacing) * 4);
  }
  .bottom-0 {
    bottom: calc(var(--spacing) * 0);
  }
  .left-0 {
    left: calc(var(--spacing) * 0);
  }
  .left-3 {
    left: calc(var(--spacing) * 3);
  }
  .-z-10 {
    z-index: calc(10 * -1);
  }
  .z-10 {
    z-index: 10;
  }
  .z-50 {
    z-index: 50;
  }
  .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;
    }
  }
  .list-base {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
  }
  .mx-1 {
    margin-inline: calc(var(--spacing) * 1);
  }
  .mx-2 {
    margin-inline: calc(var(--spacing) * 2);
  }
  .mx-auto {
    margin-inline: auto;
  }
  .my-6 {
    margin-block: calc(var(--spacing) * 6);
  }
  .-mt-20 {
    margin-top: calc(var(--spacing) * -20);
  }
  .mt-0\.5 {
    margin-top: calc(var(--spacing) * 0.5);
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .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-6 {
    margin-top: calc(var(--spacing) * 6);
  }
  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }
  .mt-12 {
    margin-top: calc(var(--spacing) * 12);
  }
  .mr-1 {
    margin-right: calc(var(--spacing) * 1);
  }
  .mr-2 {
    margin-right: calc(var(--spacing) * 2);
  }
  .mr-3 {
    margin-right: calc(var(--spacing) * 3);
  }
  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }
  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }
  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }
  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }
  .mb-12 {
    margin-bottom: calc(var(--spacing) * 12);
  }
  .-ml-\[0\.10em\] {
    margin-left: calc(0.10em * -1);
  }
  .ml-1 {
    margin-left: calc(var(--spacing) * 1);
  }
  .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-11 {
    margin-left: calc(var(--spacing) * 11);
  }
  .stack-medium {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }
  .stack-small {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .stack-tight {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
  .cluster {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
  }
  .line-clamp-1 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
  }
  .line-clamp-2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  .block {
    display: block;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline {
    display: inline;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .list-item {
    display: list-item;
  }
  .aspect-\[4\/3\] {
    aspect-ratio: 4/3;
  }
  .h-3 {
    height: calc(var(--spacing) * 3);
  }
  .h-4 {
    height: calc(var(--spacing) * 4);
  }
  .h-5 {
    height: calc(var(--spacing) * 5);
  }
  .h-6 {
    height: calc(var(--spacing) * 6);
  }
  .h-8 {
    height: calc(var(--spacing) * 8);
  }
  .h-12 {
    height: calc(var(--spacing) * 12);
  }
  .h-16 {
    height: calc(var(--spacing) * 16);
  }
  .h-24 {
    height: calc(var(--spacing) * 24);
  }
  .h-48 {
    height: calc(var(--spacing) * 48);
  }
  .h-\[500px\] {
    height: 500px;
  }
  .h-auto {
    height: auto;
  }
  .h-full {
    height: 100%;
  }
  .w-3 {
    width: calc(var(--spacing) * 3);
  }
  .w-4 {
    width: calc(var(--spacing) * 4);
  }
  .w-5 {
    width: calc(var(--spacing) * 5);
  }
  .w-6 {
    width: calc(var(--spacing) * 6);
  }
  .w-8 {
    width: calc(var(--spacing) * 8);
  }
  .w-12 {
    width: calc(var(--spacing) * 12);
  }
  .w-16 {
    width: calc(var(--spacing) * 16);
  }
  .w-24 {
    width: calc(var(--spacing) * 24);
  }
  .w-32 {
    width: calc(var(--spacing) * 32);
  }
  .w-48 {
    width: calc(var(--spacing) * 48);
  }
  .w-full {
    width: 100%;
  }
  .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-6xl {
    max-width: var(--container-6xl);
  }
  .max-w-7xl {
    max-width: var(--container-7xl);
  }
  .max-w-full {
    max-width: 100%;
  }
  .max-w-none {
    max-width: none;
  }
  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }
  .flex-1 {
    flex: 1;
  }
  .flex-shrink {
    flex-shrink: 1;
  }
  .flex-grow {
    flex-grow: 1;
  }
  .origin-top-right {
    transform-origin: 100% 0;
  }
  .-translate-y-1 {
    --tw-translate-y: calc(var(--spacing) * -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-2 {
    --tw-translate-y: calc(var(--spacing) * 2);
    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);
  }
  .rotate-180 {
    rotate: 180deg;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .animate-spin {
    animation: var(--animate-spin);
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .resize {
    resize: both;
  }
  .grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .list-horizontal {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .flex-col {
    flex-direction: column;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-center {
    align-items: center;
  }
  .items-start {
    align-items: flex-start;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }
  .gap-8 {
    gap: calc(var(--spacing) * 8);
  }
  .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-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-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-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-4 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 4) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .space-x-6 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 6) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .overflow-auto {
    overflow: auto;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .rounded-2xl {
    border-radius: var(--radius-2xl);
  }
  .rounded-full {
    border-radius: calc(infinity * 1px);
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .rounded-md {
    border-radius: var(--radius-md);
  }
  .rounded-xs {
    border-radius: var(--radius-xs);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-8 {
    border-style: var(--tw-border-style);
    border-width: 8px;
  }
  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }
  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
  .border-b-2 {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 2px;
  }
  .border-l-2 {
    border-left-style: var(--tw-border-style);
    border-left-width: 2px;
  }
  .border-l-4 {
    border-left-style: var(--tw-border-style);
    border-left-width: 4px;
  }
  .border-none {
    --tw-border-style: none;
    border-style: none;
  }
  .border-blue-500 {
    border-color: var(--color-blue-500);
  }
  .border-cyan-400 {
    border-color: var(--color-cyan-400);
  }
  .border-gray-200 {
    border-color: var(--color-gray-200);
  }
  .border-gray-300 {
    border-color: var(--color-gray-300);
  }
  .border-slate-200 {
    border-color: var(--color-slate-200);
  }
  .border-slate-300 {
    border-color: var(--color-slate-300);
  }
  .border-stone-300 {
    border-color: var(--color-stone-300);
  }
  .border-transparent {
    border-color: transparent;
  }
  .bg-amber-50 {
    background-color: var(--color-amber-50);
  }
  .bg-amber-100 {
    background-color: var(--color-amber-100);
  }
  .bg-black\/0 {
    background-color: color-mix(in srgb, #000 0%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 0%, 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\/70 {
    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);
    }
  }
  .bg-blue-100 {
    background-color: var(--color-blue-100);
  }
  .bg-blue-600 {
    background-color: var(--color-blue-600);
  }
  .bg-emerald-100 {
    background-color: var(--color-emerald-100);
  }
  .bg-fuchsia-500 {
    background-color: var(--color-fuchsia-500);
  }
  .bg-gray-50 {
    background-color: var(--color-gray-50);
  }
  .bg-gray-100 {
    background-color: var(--color-gray-100);
  }
  .bg-green-500 {
    background-color: var(--color-green-500);
  }
  .bg-sky-50 {
    background-color: var(--color-sky-50);
  }
  .bg-sky-100 {
    background-color: var(--color-sky-100);
  }
  .bg-slate-100 {
    background-color: var(--color-slate-100);
  }
  .bg-slate-200 {
    background-color: var(--color-slate-200);
  }
  .bg-transparent {
    background-color: transparent;
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .bg-white\/90 {
    background-color: color-mix(in srgb, #fff 90%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 90%, transparent);
    }
  }
  .bg-yellow-400 {
    background-color: var(--color-yellow-400);
  }
  .bg-gradient-to-r {
    --tw-gradient-position: to right in oklab;
    background-image: linear-gradient(var(--tw-gradient-stops));
  }
  .bg-gradient-to-t {
    --tw-gradient-position: to top in oklab;
    background-image: linear-gradient(var(--tw-gradient-stops));
  }
  .from-black\/60 {
    --tw-gradient-from: color-mix(in srgb, #000 60%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-gradient-from: color-mix(in oklab, var(--color-black) 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-black\/80 {
    --tw-gradient-from: color-mix(in srgb, #000 80%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-gradient-from: color-mix(in oklab, var(--color-black) 80%, 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));
  }
  .via-black\/30 {
    --tw-gradient-via: color-mix(in srgb, #000 30%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-gradient-via: color-mix(in oklab, var(--color-black) 30%, transparent);
    }
    --tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);
    --tw-gradient-stops: var(--tw-gradient-via-stops);
  }
  .to-transparent {
    --tw-gradient-to: transparent;
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .object-cover {
    object-fit: cover;
  }
  .p-1\.5 {
    padding: calc(var(--spacing) * 1.5);
  }
  .p-2 {
    padding: calc(var(--spacing) * 2);
  }
  .p-3 {
    padding: calc(var(--spacing) * 3);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .p-6 {
    padding: calc(var(--spacing) * 6);
  }
  .px-1 {
    padding-inline: calc(var(--spacing) * 1);
  }
  .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-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .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-6 {
    padding-block: calc(var(--spacing) * 6);
  }
  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }
  .py-12 {
    padding-block: calc(var(--spacing) * 12);
  }
  .py-16 {
    padding-block: calc(var(--spacing) * 16);
  }
  .py-20 {
    padding-block: calc(var(--spacing) * 20);
  }
  .pt-1 {
    padding-top: calc(var(--spacing) * 1);
  }
  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }
  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }
  .pt-8 {
    padding-top: calc(var(--spacing) * 8);
  }
  .pt-20 {
    padding-top: calc(var(--spacing) * 20);
  }
  .pt-40 {
    padding-top: calc(var(--spacing) * 40);
  }
  .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-8 {
    padding-bottom: calc(var(--spacing) * 8);
  }
  .pl-3 {
    padding-left: calc(var(--spacing) * 3);
  }
  .pl-4 {
    padding-left: calc(var(--spacing) * 4);
  }
  .pl-6 {
    padding-left: calc(var(--spacing) * 6);
  }
  .text-center {
    text-align: center;
  }
  .text-right {
    text-align: right;
  }
  .font-mono {
    font-family: var(--font-mono);
  }
  .text-metadata-large {
    font-size: 1rem;
    color: var(--color-text-secondary);
    font-weight: 500;
    line-height: 1.5;
  }
  .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-6xl {
    font-size: var(--text-6xl);
    line-height: var(--tw-leading, var(--text-6xl--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));
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }
  .text-amber-600 {
    color: var(--color-amber-600);
  }
  .text-amber-800 {
    color: var(--color-amber-800);
  }
  .text-blue-500 {
    color: var(--color-blue-500);
  }
  .text-blue-600 {
    color: var(--color-blue-600);
  }
  .text-blue-800 {
    color: var(--color-blue-800);
  }
  .text-emerald-800 {
    color: var(--color-emerald-800);
  }
  .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-800 {
    color: var(--color-gray-800);
  }
  .text-gray-900 {
    color: var(--color-gray-900);
  }
  .text-green-500 {
    color: var(--color-green-500);
  }
  .text-green-600 {
    color: var(--color-green-600);
  }
  .text-orange-600 {
    color: var(--color-orange-600);
  }
  .text-purple-600 {
    color: var(--color-purple-600);
  }
  .text-sky-600 {
    color: var(--color-sky-600);
  }
  .text-sky-800 {
    color: var(--color-sky-800);
  }
  .text-slate-400 {
    color: var(--color-slate-400);
  }
  .text-slate-500 {
    color: var(--color-slate-500);
  }
  .text-slate-600 {
    color: var(--color-slate-600);
  }
  .text-slate-700 {
    color: var(--color-slate-700);
  }
  .text-slate-900 {
    color: var(--color-slate-900);
  }
  .text-white {
    color: var(--color-white);
  }
  .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-500 {
    color: var(--color-yellow-500);
  }
  .text-yellow-900 {
    color: var(--color-yellow-900);
  }
  .uppercase {
    text-transform: uppercase;
  }
  .italic {
    font-style: italic;
  }
  .no-underline {
    text-decoration-line: none;
  }
  .underline {
    text-decoration-line: underline;
  }
  .opacity-0 {
    opacity: 0%;
  }
  .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-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-none {
    --tw-shadow: 0 0 #0000;
    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);
  }
  .ring {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .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-black {
    --tw-ring-color: var(--color-black);
  }
  .blur {
    --tw-blur: blur(8px);
    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-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-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, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-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);
  }
  .group-hover\:translate-y-0 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        --tw-translate-y: calc(var(--spacing) * 0);
        translate: var(--tw-translate-x) var(--tw-translate-y);
      }
    }
  }
  .group-hover\:scale-105 {
    &:is(:where(.group):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);
      }
    }
  }
  .group-hover\:bg-black\/20 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        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);
        }
      }
    }
  }
  .group-hover\:bg-sky-100 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        background-color: var(--color-sky-100);
      }
    }
  }
  .group-hover\:text-amber-500 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: var(--color-amber-500);
      }
    }
  }
  .group-hover\:text-blue-400 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: var(--color-blue-400);
      }
    }
  }
  .group-hover\:text-sky-800 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        color: var(--color-sky-800);
      }
    }
  }
  .group-hover\:opacity-100 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        opacity: 100%;
      }
    }
  }
  .hover\:border-gray-300 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-gray-300);
      }
    }
  }
  .hover\:border-slate-400 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-slate-400);
      }
    }
  }
  .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-700 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-blue-700);
      }
    }
  }
  .hover\:bg-gray-50 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-50);
      }
    }
  }
  .hover\:bg-gray-100 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-100);
      }
    }
  }
  .hover\:bg-gray-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-200);
      }
    }
  }
  .hover\:bg-sky-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-sky-200);
      }
    }
  }
  .hover\:bg-slate-100 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-slate-100);
      }
    }
  }
  .hover\:bg-slate-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-slate-200);
      }
    }
  }
  .hover\:text-blue-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-blue-600);
      }
    }
  }
  .hover\:text-blue-700 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-blue-700);
      }
    }
  }
  .hover\:text-blue-800 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-blue-800);
      }
    }
  }
  .hover\:text-gray-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-600);
      }
    }
  }
  .hover\:text-gray-700 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-700);
      }
    }
  }
  .hover\:text-gray-900 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-900);
      }
    }
  }
  .hover\:underline {
    &:hover {
      @media (hover: hover) {
        text-decoration-line: underline;
      }
    }
  }
  .hover\:opacity-100 {
    &:hover {
      @media (hover: hover) {
        opacity: 100%;
      }
    }
  }
  .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);
      }
    }
  }
  .focus\:not-sr-only {
    &:focus {
      position: static;
      width: auto;
      height: auto;
      padding: 0;
      margin: 0;
      overflow: visible;
      clip-path: none;
      white-space: normal;
    }
  }
  .focus\:absolute {
    &:focus {
      position: absolute;
    }
  }
  .focus\:top-4 {
    &:focus {
      top: calc(var(--spacing) * 4);
    }
  }
  .focus\:left-4 {
    &:focus {
      left: calc(var(--spacing) * 4);
    }
  }
  .focus\:outline-none {
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
    }
  }
  .sm\:flex {
    @media (width >= 40rem) {
      display: flex;
    }
  }
  .sm\:hidden {
    @media (width >= 40rem) {
      display: none;
    }
  }
  .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\:flex-row {
    @media (width >= 40rem) {
      flex-direction: row;
    }
  }
  .sm\:items-center {
    @media (width >= 40rem) {
      align-items: center;
    }
  }
  .sm\:justify-between {
    @media (width >= 40rem) {
      justify-content: space-between;
    }
  }
  .sm\:space-y-0 {
    @media (width >= 40rem) {
      :where(& > :not(:last-child)) {
        --tw-space-y-reverse: 0;
        margin-block-start: calc(calc(var(--spacing) * 0) * var(--tw-space-y-reverse));
        margin-block-end: calc(calc(var(--spacing) * 0) * calc(1 - var(--tw-space-y-reverse)));
      }
    }
  }
  .sm\:px-6 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 6);
    }
  }
  .sm\:text-left {
    @media (width >= 40rem) {
      text-align: left;
    }
  }
  .md\:mb-4 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 4);
    }
  }
  .md\:mb-6 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 6);
    }
  }
  .md\:mb-8 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 8);
    }
  }
  .md\:mb-12 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 12);
    }
  }
  .md\:mb-16 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 16);
    }
  }
  .md\:ml-6 {
    @media (width >= 48rem) {
      margin-left: calc(var(--spacing) * 6);
    }
  }
  .md\:block {
    @media (width >= 48rem) {
      display: block;
    }
  }
  .md\:flex {
    @media (width >= 48rem) {
      display: flex;
    }
  }
  .md\:hidden {
    @media (width >= 48rem) {
      display: none;
    }
  }
  .md\:h-20 {
    @media (width >= 48rem) {
      height: calc(var(--spacing) * 20);
    }
  }
  .md\:w-20 {
    @media (width >= 48rem) {
      width: calc(var(--spacing) * 20);
    }
  }
  .md\:grid-cols-2 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .md\:gap-6 {
    @media (width >= 48rem) {
      gap: calc(var(--spacing) * 6);
    }
  }
  .md\:gap-8 {
    @media (width >= 48rem) {
      gap: calc(var(--spacing) * 8);
    }
  }
  .md\:space-x-8 {
    @media (width >= 48rem) {
      :where(& > :not(:last-child)) {
        --tw-space-x-reverse: 0;
        margin-inline-start: calc(calc(var(--spacing) * 8) * var(--tw-space-x-reverse));
        margin-inline-end: calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-x-reverse)));
      }
    }
  }
  .md\:px-6 {
    @media (width >= 48rem) {
      padding-inline: calc(var(--spacing) * 6);
    }
  }
  .md\:py-16 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 16);
    }
  }
  .md\:text-2xl {
    @media (width >= 48rem) {
      font-size: var(--text-2xl);
      line-height: var(--tw-leading, var(--text-2xl--line-height));
    }
  }
  .md\:text-4xl {
    @media (width >= 48rem) {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }
  .md\:text-6xl {
    @media (width >= 48rem) {
      font-size: var(--text-6xl);
      line-height: var(--tw-leading, var(--text-6xl--line-height));
    }
  }
  .md\:text-xl {
    @media (width >= 48rem) {
      font-size: var(--text-xl);
      line-height: var(--tw-leading, var(--text-xl--line-height));
    }
  }
  .lg\:grid-cols-3 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .lg\:px-8 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 8);
    }
  }
  .dark\:border {
    &:where(.dark, .dark *) {
      border-style: var(--tw-border-style);
      border-width: 1px;
    }
  }
  .dark\:border-amber-400 {
    &:where(.dark, .dark *) {
      border-color: var(--color-amber-400);
    }
  }
  .dark\:border-gray-600 {
    &:where(.dark, .dark *) {
      border-color: var(--color-gray-600);
    }
  }
  .dark\:border-gray-700 {
    &:where(.dark, .dark *) {
      border-color: var(--color-gray-700);
    }
  }
  .dark\:border-slate-700 {
    &:where(.dark, .dark *) {
      border-color: var(--color-slate-700);
    }
  }
  .dark\:border-stone-100 {
    &:where(.dark, .dark *) {
      border-color: var(--color-stone-100);
    }
  }
  .dark\:border-stone-600 {
    &:where(.dark, .dark *) {
      border-color: var(--color-stone-600);
    }
  }
  .dark\:border-stone-700 {
    &:where(.dark, .dark *) {
      border-color: var(--color-stone-700);
    }
  }
  .dark\:border-zinc-700 {
    &:where(.dark, .dark *) {
      border-color: var(--color-zinc-700);
    }
  }
  .dark\:bg-amber-900 {
    &:where(.dark, .dark *) {
      background-color: var(--color-amber-900);
    }
  }
  .dark\:bg-amber-900\/20 {
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(41.4% 0.112 45.904) 20%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-amber-900) 20%, transparent);
      }
    }
  }
  .dark\:bg-blue-900 {
    &:where(.dark, .dark *) {
      background-color: var(--color-blue-900);
    }
  }
  .dark\:bg-current\/\[3\%\] {
    &:where(.dark, .dark *) {
      background-color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, currentcolor 3%, transparent);
      }
    }
  }
  .dark\:bg-emerald-900 {
    &:where(.dark, .dark *) {
      background-color: var(--color-emerald-900);
    }
  }
  .dark\:bg-gray-700 {
    &:where(.dark, .dark *) {
      background-color: var(--color-gray-700);
    }
  }
  .dark\:bg-gray-800 {
    &:where(.dark, .dark *) {
      background-color: var(--color-gray-800);
    }
  }
  .dark\:bg-gray-800\/90 {
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(27.8% 0.033 256.848) 90%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-gray-800) 90%, transparent);
      }
    }
  }
  .dark\:bg-gray-900 {
    &:where(.dark, .dark *) {
      background-color: var(--color-gray-900);
    }
  }
  .dark\:bg-sky-800 {
    &:where(.dark, .dark *) {
      background-color: var(--color-sky-800);
    }
  }
  .dark\:bg-sky-900\/20 {
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(39.1% 0.09 240.876) 20%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-sky-900) 20%, transparent);
      }
    }
  }
  .dark\:bg-slate-800 {
    &:where(.dark, .dark *) {
      background-color: var(--color-slate-800);
    }
  }
  .dark\:bg-stone-500 {
    &:where(.dark, .dark *) {
      background-color: var(--color-stone-500);
    }
  }
  .dark\:bg-stone-600 {
    &:where(.dark, .dark *) {
      background-color: var(--color-stone-600);
    }
  }
  .dark\:bg-stone-700 {
    &:where(.dark, .dark *) {
      background-color: var(--color-stone-700);
    }
  }
  .dark\:bg-zinc-700 {
    &:where(.dark, .dark *) {
      background-color: var(--color-zinc-700);
    }
  }
  .dark\:bg-zinc-800 {
    &:where(.dark, .dark *) {
      background-color: var(--color-zinc-800);
    }
  }
  .dark\:bg-zinc-900 {
    &:where(.dark, .dark *) {
      background-color: var(--color-zinc-900);
    }
  }
  .dark\:text-amber-50 {
    &:where(.dark, .dark *) {
      color: var(--color-amber-50);
    }
  }
  .dark\:text-amber-200 {
    &:where(.dark, .dark *) {
      color: var(--color-amber-200);
    }
  }
  .dark\:text-amber-400 {
    &:where(.dark, .dark *) {
      color: var(--color-amber-400);
    }
  }
  .dark\:text-blue-200 {
    &:where(.dark, .dark *) {
      color: var(--color-blue-200);
    }
  }
  .dark\:text-blue-400 {
    &:where(.dark, .dark *) {
      color: var(--color-blue-400);
    }
  }
  .dark\:text-emerald-200 {
    &:where(.dark, .dark *) {
      color: var(--color-emerald-200);
    }
  }
  .dark\:text-gray-100 {
    &:where(.dark, .dark *) {
      color: var(--color-gray-100);
    }
  }
  .dark\:text-gray-200 {
    &:where(.dark, .dark *) {
      color: var(--color-gray-200);
    }
  }
  .dark\:text-gray-300 {
    &:where(.dark, .dark *) {
      color: var(--color-gray-300);
    }
  }
  .dark\:text-gray-400 {
    &:where(.dark, .dark *) {
      color: var(--color-gray-400);
    }
  }
  .dark\:text-gray-500 {
    &:where(.dark, .dark *) {
      color: var(--color-gray-500);
    }
  }
  .dark\:text-green-400 {
    &:where(.dark, .dark *) {
      color: var(--color-green-400);
    }
  }
  .dark\:text-orange-400 {
    &:where(.dark, .dark *) {
      color: var(--color-orange-400);
    }
  }
  .dark\:text-purple-400 {
    &:where(.dark, .dark *) {
      color: var(--color-purple-400);
    }
  }
  .dark\:text-sky-200 {
    &:where(.dark, .dark *) {
      color: var(--color-sky-200);
    }
  }
  .dark\:text-sky-400 {
    &:where(.dark, .dark *) {
      color: var(--color-sky-400);
    }
  }
  .dark\:text-slate-200 {
    &:where(.dark, .dark *) {
      color: var(--color-slate-200);
    }
  }
  .dark\:text-slate-300 {
    &:where(.dark, .dark *) {
      color: var(--color-slate-300);
    }
  }
  .dark\:text-slate-400 {
    &:where(.dark, .dark *) {
      color: var(--color-slate-400);
    }
  }
  .dark\:text-slate-500 {
    &:where(.dark, .dark *) {
      color: var(--color-slate-500);
    }
  }
  .dark\:text-stone-100 {
    &:where(.dark, .dark *) {
      color: var(--color-stone-100);
    }
  }
  .dark\:text-stone-200 {
    &:where(.dark, .dark *) {
      color: var(--color-stone-200);
    }
  }
  .dark\:text-stone-300 {
    &:where(.dark, .dark *) {
      color: var(--color-stone-300);
    }
  }
  .dark\:text-stone-400 {
    &:where(.dark, .dark *) {
      color: var(--color-stone-400);
    }
  }
  .dark\:text-stone-500 {
    &:where(.dark, .dark *) {
      color: var(--color-stone-500);
    }
  }
  .dark\:text-white {
    &:where(.dark, .dark *) {
      color: var(--color-white);
    }
  }
  .dark\:shadow-none {
    &:where(.dark, .dark *) {
      --tw-shadow: 0 0 #0000;
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .dark\:group-hover\:bg-sky-800 {
    &:where(.dark, .dark *) {
      &:is(:where(.group):hover *) {
        @media (hover: hover) {
          background-color: var(--color-sky-800);
        }
      }
    }
  }
  .dark\:group-hover\:text-sky-200 {
    &:where(.dark, .dark *) {
      &:is(:where(.group):hover *) {
        @media (hover: hover) {
          color: var(--color-sky-200);
        }
      }
    }
  }
  .dark\:hover\:bg-gray-700 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          background-color: var(--color-gray-700);
        }
      }
    }
  }
  .dark\:hover\:bg-sky-700 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          background-color: var(--color-sky-700);
        }
      }
    }
  }
  .dark\:hover\:bg-stone-600 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          background-color: var(--color-stone-600);
        }
      }
    }
  }
  .dark\:hover\:bg-stone-700 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          background-color: var(--color-stone-700);
        }
      }
    }
  }
  .dark\:hover\:bg-zinc-700 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          background-color: var(--color-zinc-700);
        }
      }
    }
  }
  .dark\:hover\:text-blue-200 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-blue-200);
        }
      }
    }
  }
  .dark\:hover\:text-blue-300 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-blue-300);
        }
      }
    }
  }
  .dark\:hover\:text-blue-400 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-blue-400);
        }
      }
    }
  }
  .dark\:hover\:text-gray-100 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-gray-100);
        }
      }
    }
  }
  .dark\:hover\:text-gray-300 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-gray-300);
        }
      }
    }
  }
  .dark\:hover\:text-stone-200 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-stone-200);
        }
      }
    }
  }
  .dark\:hover\:text-stone-300 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-stone-300);
        }
      }
    }
  }
  .dark\:hover\:text-white {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-white);
        }
      }
    }
  }
  .dark\:hover\:text-yellow-500 {
    &:where(.dark, .dark *) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-yellow-500);
        }
      }
    }
  }
}
@layer reset;
@layer base {
  ::selection {
    background: var(--color-brand-primary, oklch(54.6% 0.245 262.881));
    color: #fff;
  }
  :focus:not(:focus-visible) {
    outline: none;
  }
  :focus-visible {
    outline: 2px solid var(--color-brand-primary, oklch(54.6% 0.245 262.881));
    outline-offset: 2px;
  }
  html {
    scroll-behavior: smooth;
  }
  html, body {
    overflow-x: hidden;
  }
  ::-webkit-scrollbar {
    width: 0.5rem;
  }
  ::-webkit-scrollbar-track {
    background: var(--color-background-subtle, oklch(96.7% 0.003 264.542));
  }
  ::-webkit-scrollbar-thumb {
    background: var(--color-border-default, oklch(87.2% 0.01 258.338));
    border-radius: 9999px;
  }
  ::-webkit-scrollbar-thumb:hover {
    background: var(--color-text-tertiary, oklch(55.1% 0.027 264.364));
  }
  @media print {
    * {
      background: transparent !important;
      color: black !important;
      box-shadow: none !important;
      text-shadow: none !important;
    }
    a, a:visited {
      text-decoration: underline;
    }
    abbr[title]:after {
      content: " (" attr(title) ")";
    }
    pre, blockquote {
      border: 1px solid oklch(70.7% 0.022 261.325);
      page-break-inside: avoid;
    }
    thead {
      display: table-header-group;
    }
    tr, img {
      page-break-inside: avoid;
    }
    img {
      max-width: 100% !important;
    }
    p, h2, h3 {
      orphans: 3;
      widows: 3;
    }
    h2, h3 {
      page-break-after: avoid;
    }
  }
}
@layer base {
  :root {
    --token-brand-primary: oklch(68.5% 0.169 237.323);
    --token-brand-secondary: oklch(44.4% 0.011 73.639);
    --token-neutral-50: oklch(98.5% 0.002 247.839);
    --token-neutral-100: oklch(96.7% 0.003 264.542);
    --token-neutral-200: oklch(92.8% 0.006 264.531);
    --token-neutral-300: oklch(87.2% 0.01 258.338);
    --token-neutral-400: oklch(70.7% 0.022 261.325);
    --token-neutral-500: oklch(55.1% 0.027 264.364);
    --token-neutral-600: oklch(44.6% 0.03 256.802);
    --token-neutral-700: oklch(37.3% 0.034 259.733);
    --token-neutral-800: oklch(27.8% 0.033 256.848);
    --token-neutral-900: oklch(21% 0.034 264.665);
    --token-neutral-950: oklch(13% 0.028 261.692);
    --token-success-base: oklch(62.7% 0.194 149.214);
    --token-danger-base: oklch(57.7% 0.245 27.325);
    --token-warning-base: oklch(68.1% 0.162 75.834);
    --token-info-base: oklch(58.8% 0.158 241.966);
    --token-elevated-base: oklch(96.7% 0.001 286.375);
    --token-pure-white: #fff;
    --token-pure-black: #000;
    --token-shadow-subtle: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
    --token-shadow-default: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --token-shadow-elevated: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --token-shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
    --token-shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    --token-shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.06);
    --token-shadow-inner-strong: inset 0 4px 8px 0 rgba(0, 0, 0, 0.1);
  }
}
@layer base {
  :root {
    --color-background-primary: var(--token-neutral-50);
    --color-background-secondary: var(--token-neutral-100);
    --color-background-subtle: var(--token-neutral-100);
    --color-background-elevated: var(--token-elevated-base);
    --color-text-primary: var(--token-neutral-900);
    --color-text-secondary: var(--token-neutral-700);
    --color-text-tertiary: var(--token-neutral-500);
    --color-border-default: var(--token-neutral-300);
    --color-border-subtle: var(--token-neutral-200);
    --color-brand-primary: var(--token-brand-primary);
    --color-brand-secondary: var(--token-brand-secondary);
    --color-success: var(--token-success-base);
    --color-danger: var(--token-danger-base);
    --color-warning: var(--token-warning-base);
    --color-info: var(--token-info-base);
    --color-brand-primary-lighter: oklch(
      from var(--color-brand-primary) calc(l + 0.25) c h
    );
    --color-brand-primary-light: oklch(
      from var(--color-brand-primary) calc(l + 0.15) c h
    );
    --color-brand-primary-dark: oklch(
      from var(--color-brand-primary) calc(l - 0.15) c h
    );
    --color-brand-primary-darker: oklch(
      from var(--color-brand-primary) calc(l - 0.25) c h
    );
    --color-brand-primary-vibrant: oklch(
      from var(--color-brand-primary) l calc(c * 1.3) h
    );
    --color-brand-primary-muted: oklch(
      from var(--color-brand-primary) l calc(c * 0.6) h
    );
    --color-brand-primary-subtle: oklch(
      from var(--color-brand-primary) l calc(c * 0.3) h
    );
    --color-brand-primary-desaturated: oklch(
      from var(--color-brand-primary) l calc(c * 0.5) h
    );
    --color-brand-primary-ghost: oklch(
      from var(--color-brand-primary) l c h / 0.08
    );
    --color-brand-primary-whisper: oklch(
      from var(--color-brand-primary) l c h / 0.05
    );
    --color-brand-primary-overlay: oklch(
      from var(--color-brand-primary) l c h / 0.15
    );
    --color-brand-primary-backdrop: oklch(
      from var(--color-brand-primary) l c h / 0.25
    );
    --color-brand-secondary-light: oklch(
      from var(--color-brand-secondary) calc(l + 0.15) c h
    );
    --color-brand-secondary-dark: oklch(
      from var(--color-brand-secondary) calc(l - 0.15) c h
    );
    --color-brand-secondary-muted: oklch(
      from var(--color-brand-secondary) l calc(c * 0.6) h
    );
    --color-brand-secondary-overlay: oklch(
      from var(--color-brand-secondary) l c h / 0.15
    );
    --color-success-light: oklch(
      from var(--color-success) calc(l + 0.20) c h
    );
    --color-success-dark: oklch(
      from var(--color-success) calc(l - 0.20) c h
    );
    --color-success-ghost: oklch(
      from var(--color-success) l c h / 0.1
    );
    --color-success-muted: oklch(
      from var(--color-success) l calc(c * 0.8) h
    );
    --color-danger-light: oklch(
      from var(--color-danger) calc(l + 0.20) c h
    );
    --color-danger-dark: oklch(
      from var(--color-danger) calc(l - 0.20) c h
    );
    --color-danger-ghost: oklch(
      from var(--color-danger) l c h / 0.1
    );
    --color-danger-muted: oklch(
      from var(--color-danger) l calc(c * 0.8) h
    );
    --color-warning-light: oklch(
      from var(--color-warning) calc(l + 0.20) c h
    );
    --color-warning-dark: oklch(
      from var(--color-warning) calc(l - 0.20) c h
    );
    --color-warning-ghost: oklch(
      from var(--color-warning) l c h / 0.1
    );
    --color-warning-muted: oklch(
      from var(--color-warning) l calc(c * 0.8) h
    );
    --color-info-light: oklch(
      from var(--color-info) calc(l + 0.20) c h
    );
    --color-info-dark: oklch(
      from var(--color-info) calc(l - 0.20) c h
    );
    --color-info-ghost: oklch(
      from var(--color-info) l c h / 0.1
    );
    --color-info-muted: oklch(
      from var(--color-info) l calc(c * 0.8) h
    );
    --color-hover-default: oklch(
      from var(--color-brand-primary) calc(l - 0.08) c h
    );
    --color-active-default: oklch(
      from var(--color-brand-primary) calc(l - 0.12) c h
    );
    --color-focus-ring: oklch(
      from var(--color-brand-primary) l c h / 0.25
    );
    --color-text-inverted-primary: var(--token-neutral-50);
    --color-text-inverted-secondary: var(--token-neutral-200);
    --color-text-inverted-tertiary: var(--token-neutral-300);
    --color-text-on-brand: var(--token-pure-white);
    --color-text-on-dark: var(--token-neutral-50);
    --color-text-on-brand: oklch(
      from var(--color-brand-primary) calc(l > 0.60 ? 0.15 : 0.85) c h
    );
    --color-text-on-success: oklch(
      from var(--color-success) calc(l > 0.60 ? 0.15 : 0.85) c h
    );
    --color-text-on-warning: oklch(
      from var(--color-warning) calc(l > 0.60 ? 0.15 : 0.85) c h
    );
    --color-text-on-danger: oklch(
      from var(--color-danger) calc(l > 0.60 ? 0.15 : 0.85) c h
    );
    --focus-ring-brand: oklch(
      from var(--color-brand-primary) calc(l > 0.50 ? 0.20 : 0.80) calc(max(0.15, c)) calc(h + 180)
    );
    --focus-ring-success: oklch(
      from var(--color-success) calc(l > 0.50 ? 0.20 : 0.80) calc(max(0.15, c)) calc(h + 180)
    );
    --focus-ring-warning: oklch(
      from var(--color-warning) calc(l > 0.50 ? 0.20 : 0.80) calc(max(0.15, c)) calc(h + 180)
    );
    --focus-ring-danger: oklch(
      from var(--color-danger) calc(l > 0.50 ? 0.20 : 0.80) calc(max(0.15, c)) calc(h + 180)
    );
    --color-text-accessible: oklch(
      from var(--color-text-primary) calc(l > 0.50 ? 0.10 : 0.90) c h
    );
    --color-background-accessible: oklch(
      from var(--color-background-primary) calc(l > 0.50 ? 0.95 : 0.05) c h
    );
    --color-border-accessible: oklch(
      from var(--color-border-default) calc(l > 0.50 ? 0.30 : 0.70) c h
    );
    --color-text-large: var(--color-text-primary);
    --color-text-normal: oklch(
      from var(--color-text-primary) calc(l > 0.50 ? 0.15 : 0.85) c h
    );
    --color-text-enhanced: oklch(
      from var(--color-text-primary) calc(l > 0.50 ? 0.05 : 0.95) c h
    );
    --color-success-accessible: oklch(
      from var(--color-success) calc(clamp(0.25, l, 0.75)) calc(max(0.15, c)) h
    );
    --color-danger-accessible: oklch(
      from var(--color-danger) calc(clamp(0.25, l, 0.75)) calc(max(0.15, c)) h
    );
    --color-warning-accessible: oklch(
      from var(--color-warning) calc(clamp(0.20, l, 0.70)) calc(max(0.15, c)) h
    );
    --color-info-accessible: oklch(
      from var(--color-info) calc(clamp(0.25, l, 0.75)) calc(max(0.15, c)) h
    );
    --shadow-subtle: var(--token-shadow-subtle);
    --shadow-default: var(--token-shadow-default);
    --shadow-elevated: var(--token-shadow-elevated);
    --shadow-lg: var(--token-shadow-lg);
    --shadow-xl: var(--token-shadow-xl);
    --shadow-inner: var(--token-shadow-inner);
    --shadow-inner-strong: var(--token-shadow-inner-strong);
    --shadow-brand: 0 4px 14px 0 oklch(
      from var(--color-brand-primary) l c h / 0.25
    );
    --shadow-brand-lg: 0 10px 25px 0 oklch(
      from var(--color-brand-primary) l c h / 0.2
    );
    --shadow-brand-soft: 0 4px 20px oklch(
      from var(--color-brand-primary) l c h / 0.12
    );
    --shadow-brand-sharp: 0 2px 8px oklch(
      from var(--color-brand-primary) l c h / 0.25
    );
    --shadow-brand-subtle: 0 1px 4px oklch(
      from var(--color-brand-primary) l c h / 0.15
    );
    --shadow-brand-inset: inset 0 2px 8px oklch(
      from var(--color-brand-primary) l c h / 0.1
    );
    --shadow-brand-inset-strong: inset 0 4px 12px oklch(
      from var(--color-brand-primary) l c h / 0.2
    );
    --shadow-brand-layered: 0 1px 3px oklch(from var(--color-brand-primary) l c h / 0.12),
      0 4px 12px oklch(from var(--color-brand-primary) l c h / 0.08),
      0 12px 24px oklch(from var(--color-brand-primary) l c h / 0.04);
    --shadow-success: 0 4px 14px 0 oklch(
      from var(--color-success) l c h / 0.2
    );
    --shadow-success-soft: 0 4px 20px oklch(
      from var(--color-success) l c h / 0.12
    );
    --shadow-danger: 0 4px 14px 0 oklch(
      from var(--color-danger) l c h / 0.2
    );
    --shadow-danger-soft: 0 4px 20px oklch(
      from var(--color-danger) l c h / 0.12
    );
    --shadow-warning: 0 4px 14px 0 oklch(
      from var(--color-warning) l c h / 0.2
    );
    --shadow-warning-soft: 0 4px 20px oklch(
      from var(--color-warning) l c h / 0.12
    );
    --shadow-info: 0 4px 14px 0 oklch(
      from var(--color-info) l c h / 0.2
    );
    --shadow-info-soft: 0 4px 20px oklch(
      from var(--color-info) l c h / 0.12
    );
    --shadow-focus-brand: 0 0 0 3px oklch(
      from var(--color-brand-primary) l c h / 0.2
    );
    --shadow-focus-success: 0 0 0 3px oklch(
      from var(--color-success) l c h / 0.2
    );
    --shadow-focus-danger: 0 0 0 3px oklch(
      from var(--color-danger) l c h / 0.2
    );
    --shadow-focus-warning: 0 0 0 3px oklch(
      from var(--color-warning) l c h / 0.2
    );
    --gradient-brand: linear-gradient(
      135deg,
      var(--color-brand-primary),
      var(--color-brand-secondary)
    );
    --gradient-brand-subtle: linear-gradient(
      135deg,
      oklch(from var(--color-brand-primary) l c h / 0.1),
      oklch(from var(--color-brand-secondary) l c h / 0.1)
    );
    --gradient-success: linear-gradient(
      135deg,
      var(--color-success),
      oklch(from var(--color-success) calc(l + 0.15) calc(c * 1.1) h)
    );
    --gradient-danger: linear-gradient(
      135deg,
      var(--color-danger),
      oklch(from var(--color-danger) calc(l + 0.15) calc(c * 1.1) h)
    );
  }
  @media (prefers-contrast: high) {
    :root {
      --color-text-enhanced: oklch(
        from var(--color-text-primary) calc(l < 0.50 ? 0.05 : 0.95) c h
      );
      --color-background-enhanced: oklch(
        from var(--color-background-primary) calc(l < 0.50 ? 0.95 : 0.05) c h
      );
      --color-border-enhanced: oklch(
        from var(--color-border-default) calc(l < 0.50 ? 0.80 : 0.20) c h
      );
      --focus-outline-width: 3px;
      --focus-outline-offset: 3px;
    }
  }
  @media print {
    :root {
      --color-text-print: #000000;
      --color-background-print: #ffffff;
      --color-border-print: #000000;
      --color-brand-print: oklch(
        from var(--color-brand-primary) calc(clamp(0.20, l, 0.80)) calc(max(0.12, c)) h
      );
    }
  }
  @media (forced-colors: active) {
    :root {
      --color-text-forced: CanvasText;
      --color-background-forced: Canvas;
      --color-border-forced: ButtonBorder;
      --color-link-forced: LinkText;
      --color-focus-forced: Highlight;
    }
  }
}
@layer base {
  :root {
    --font-family-primary: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-family-heading: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-family-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --font-size-xs: clamp(0.75rem, 0.7rem + 0.25vw, 0.875rem);
    --font-size-sm: clamp(0.875rem, 0.8rem + 0.375vw, 1rem);
    --font-size-base: clamp(1rem, 0.9rem + 0.5vw, 1.125rem);
    --font-size-lg: clamp(1.125rem, 1rem + 0.625vw, 1.25rem);
    --font-size-xl: clamp(1.25rem, 1.1rem + 0.75vw, 1.5rem);
    --font-size-2xl: clamp(1.5rem, 1.3rem + 1vw, 1.875rem);
    --font-size-3xl: clamp(1.875rem, 1.6rem + 1.375vw, 2.25rem);
    --line-height-tight: 1.25;
    --line-height-normal: 1.5;
    --line-height-relaxed: 1.625;
    --line-height-loose: 2;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --spacing-component-xs: 0.25rem;
    --spacing-component-sm: 0.5rem;
    --spacing-component-md: 1rem;
    --spacing-component-lg: 1.5rem;
    --spacing-component-xl: 2rem;
    --spacing-component-2xl: 3rem;
    --spacing-responsive-xs: clamp(0.25rem, 0.2rem + 0.25vw, 0.5rem);
    --spacing-responsive-sm: clamp(0.5rem, 0.4rem + 0.5vw, 1rem);
    --spacing-responsive-md: clamp(1rem, 0.8rem + 1vw, 2rem);
    --spacing-responsive-lg: clamp(1.5rem, 1.2rem + 1.5vw, 3rem);
    --spacing-responsive-xl: clamp(2rem, 1.6rem + 2vw, 4rem);
    --spacing-0: 0;
    --spacing-px: 1px;
    --spacing-0-5: 0.125rem;
    --spacing-1: 0.25rem;
    --spacing-1-5: 0.375rem;
    --spacing-2: 0.5rem;
    --spacing-2-5: 0.625rem;
    --spacing-3: 0.75rem;
    --spacing-3-5: 0.875rem;
    --spacing-4: 1rem;
    --spacing-5: 1.25rem;
    --spacing-6: 1.5rem;
    --spacing-7: 1.75rem;
    --spacing-8: 2rem;
    --spacing-9: 2.25rem;
    --spacing-10: 2.5rem;
    --spacing-11: 2.75rem;
    --spacing-12: 3rem;
    --spacing-14: 3.5rem;
    --spacing-16: 4rem;
    --spacing-20: 5rem;
    --spacing-24: 6rem;
    --spacing-28: 7rem;
    --spacing-32: 8rem;
    --spacing-36: 9rem;
    --spacing-40: 10rem;
    --spacing-44: 11rem;
    --spacing-48: 12rem;
    --spacing-52: 13rem;
    --spacing-56: 14rem;
    --spacing-60: 15rem;
    --spacing-64: 16rem;
    --spacing-72: 18rem;
    --spacing-80: 20rem;
    --spacing-96: 24rem;
    --radius-none: 0;
    --radius-xs: 0.25rem;
    --radius-sm: 0.375rem;
    --radius-md: 0.5rem;
    --radius-lg: 0.75rem;
    --radius-xl: 1rem;
    --radius-2xl: 1rem;
    --radius-3xl: 1.5rem;
    --radius-full: 9999px;
    --transition-fast: 150ms;
    --transition-normal: 200ms;
    --transition-slow: 300ms;
    --transition-slower: 500ms;
    --easing-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --easing-ease-out: cubic-bezier(0, 0, 0.2, 1);
    --easing-ease-in: cubic-bezier(0.4, 0, 1, 1);
    --easing-bounce: cubic-bezier(0.68, -0.55, 0.265, 1.55);
    --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);
    --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --shadow-none: none;
    --z-base: 0;
    --z-docked: 10;
    --z-dropdown: 1000;
    --z-sticky: 1020;
    --z-fixed: 1030;
    --z-modal-backdrop: 1040;
    --z-modal: 1050;
    --z-popover: 1060;
    --z-tooltip: 1070;
    --z-toast: 1080;
    --z-maximum: 2147483647;
    --content-width-narrow: 42rem;
    --content-width-default: 56rem;
    --content-width-wide: 72rem;
    --content-width-full: 80rem;
    --content-width-responsive: clamp(20rem, 90vw, var(--content-width-default));
    --max-width-xs: 20rem;
    --max-width-sm: 24rem;
    --max-width-md: 28rem;
    --max-width-lg: 32rem;
    --max-width-xl: 36rem;
    --max-width-2xl: 42rem;
    --max-width-3xl: 48rem;
    --max-width-4xl: 56rem;
    --max-width-5xl: 64rem;
    --max-width-6xl: 72rem;
    --max-width-7xl: 80rem;
    --max-width-full: 100%;
    --form-element-height-xs: 1.5rem;
    --form-element-height-sm: 2rem;
    --form-element-height-md: 2.5rem;
    --form-element-height-lg: 3rem;
    --form-element-height-xl: 3.5rem;
    --touch-target-min: 44px;
    --touch-target-comfortable: 48px;
    --focus-outline-width: 2px;
    --focus-outline-offset: 2px;
    --focus-outline-style: solid;
    --animation-duration-short: 150ms;
    --animation-duration-medium: 250ms;
    --animation-duration-long: 400ms;
  }
  @media (prefers-contrast: high) {
    :root {
      --focus-outline-width: 3px;
      --focus-outline-offset: 3px;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    :root {
      --transition-fast: 0ms;
      --transition-normal: 0ms;
      --transition-slow: 0ms;
      --transition-slower: 0ms;
      --animation-duration-short: 0ms;
      --animation-duration-medium: 0ms;
      --animation-duration-long: 0ms;
    }
  }
}
@layer base {
  html {
    font-family: var(--font-family-primary, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    color: var(--color-text-primary, oklch(21% 0.034 264.665));
    line-height: 1.625;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  body {
    line-height: inherit;
    color: inherit;
  }
  body:not([class*="bg-"]) {
    background-color: var(--color-background-primary);
  }
  h1, h2, h3, h4, h5, h6 {
    color: var(--color-text-primary, oklch(21% 0.034 264.665));
    font-family: var(--font-family-heading, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-weight: 600;
    line-height: 1.25;
    letter-spacing: -0.025em;
    margin-bottom: var(--spacing-component-md, 1rem);
  }
  h1 {
    font-size: 2.25rem;
    font-weight: 700;
    @media (min-width: 64rem) {
      font-size: 3rem;
    }
  }
  h2 {
    font-size: 1.875rem;
    @media (min-width: 64rem) {
      font-size: 2.25rem;
    }
  }
  h3 {
    font-size: 1.5rem;
    @media (min-width: 64rem) {
      font-size: 1.875rem;
    }
  }
  h4 {
    font-size: 1.25rem;
    @media (min-width: 64rem) {
      font-size: 1.5rem;
    }
  }
  h5 {
    font-size: 1.125rem;
    @media (min-width: 64rem) {
      font-size: 1.25rem;
    }
  }
  h6 {
    font-size: 1rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }
  p {
    margin-bottom: var(--spacing-component-md, 1rem);
    line-height: 1.625;
  }
  p:last-child {
    margin-bottom: 0;
  }
  strong, b {
    font-weight: 600;
    color: var(--color-text-primary, oklch(21% 0.034 264.665));
  }
  em, i {
    font-style: italic;
  }
  small {
    font-size: 0.875rem;
    color: var(--color-text-secondary, oklch(37.3% 0.034 259.733));
  }
  a {
    color: var(--color-brand-primary, oklch(54.6% 0.245 262.881));
    text-decoration: none;
    transition: color var(--transition-fast, 150ms);
    &:hover {
      color: var(--color-brand-secondary, oklch(55.8% 0.288 302.321));
      text-decoration: underline;
    }
    &:focus-visible {
      outline: 2px solid var(--color-brand-primary, oklch(54.6% 0.245 262.881));
      outline-offset: 2px;
      border-radius: 0.25rem;
    }
  }
  ul, ol {
    margin-bottom: var(--spacing-component-md, 1rem);
    padding-left: 1.5rem;
  }
  ul {
    list-style-type: disc;
  }
  ol {
    list-style-type: decimal;
  }
  li {
    margin-bottom: var(--spacing-component-sm, 0.5rem);
  }
  li:last-child {
    margin-bottom: 0;
  }
  code {
    font-family: var(--font-family-mono, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-size: 0.875rem;
    background: var(--color-background-subtle, oklch(96.7% 0.003 264.542));
    color: var(--color-text-primary, oklch(21% 0.034 264.665));
    padding: 0.25rem 0.5rem;
    border-radius: var(--radius-sm, 0.375rem);
  }
  pre {
    font-family: var(--font-family-mono, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-size: 0.875rem;
    background: var(--color-background-subtle, oklch(96.7% 0.003 264.542));
    color: var(--color-text-primary, oklch(21% 0.034 264.665));
    padding: var(--spacing-component-md, 1rem);
    border-radius: var(--radius-md, 0.5rem);
    overflow-x: auto;
    margin-bottom: var(--spacing-component-md, 1rem);
    code {
      background: transparent;
      padding: 0;
    }
  }
  blockquote {
    border-left: 4px solid var(--color-brand-primary, oklch(54.6% 0.245 262.881));
    padding-left: var(--spacing-component-lg, 1.5rem);
    margin-bottom: var(--spacing-component-md, 1rem);
    font-style: italic;
    color: var(--color-text-secondary, oklch(37.3% 0.034 259.733));
    font-size: 1.125rem;
  }
  hr {
    border: 0;
    height: 1px;
    background: var(--color-border-subtle, oklch(92.8% 0.006 264.531));
    margin: var(--spacing-component-xl, 2rem) 0;
  }
  table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: var(--spacing-component-md, 1rem);
  }
  th, td {
    padding: var(--spacing-component-sm, 0.5rem) var(--spacing-component-md, 1rem);
    text-align: left;
    border-bottom: 1px solid var(--color-border-subtle, oklch(92.8% 0.006 264.531));
  }
  th {
    font-weight: 600;
    color: var(--color-text-primary, oklch(21% 0.034 264.665));
    background: var(--color-background-secondary, oklch(98.5% 0.002 247.839));
  }
  img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-sm, 0.375rem);
  }
  input, textarea, select {
    font-family: inherit;
    font-size: inherit;
    color: var(--color-text-primary, oklch(21% 0.034 264.665));
  }
  address {
    font-style: normal;
    line-height: inherit;
    margin-bottom: var(--spacing-component-md, 1rem);
  }
}
@layer components {
  .btn-base {
    --btn-color: var(--color-brand-primary);
    --btn-text-color: white;
    --btn-hover-color: oklch(
      from var(--btn-color) calc(l - 0.08) calc(c * 1.1) h
    );
    --btn-active-color: oklch(
      from var(--btn-color) calc(l - 0.12) calc(c * 1.15) h
    );
    --btn-focus-color: oklch(
      from var(--btn-color) l c h / 0.25
    );
    --btn-disabled-color: oklch(
      from var(--btn-color) calc(l + 0.25) calc(c * 0.3) h
    );
    --btn-pressed-color: oklch(
      from var(--btn-color) calc(l - 0.15) calc(c * 1.2) h
    );
    --btn-shadow: 0 4px 12px oklch(
      from var(--btn-color) l c h / 0.15
    );
    --btn-shadow-hover: 0 6px 16px oklch(
      from var(--btn-color) l c h / 0.2
    );
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.25rem;
    padding: 0.5rem 1rem;
    border-radius: 0.375rem;
    background-color: var(--btn-color);
    color: var(--btn-text-color);
    border: 1px solid var(--color-border-default);
    transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    user-select: none;
    text-decoration: none;
    &:hover:not(:disabled) {
      background-color: var(--btn-hover-color);
      border-color: var(--btn-hover-color);
    }
    &:active:not(:disabled) {
      background-color: var(--btn-active-color);
      border-color: var(--btn-active-color);
    }
    &:focus-visible {
      outline: 2px solid var(--btn-focus-color);
      outline-offset: 2px;
    }
    &:disabled {
      background-color: var(--btn-disabled-color);
      border-color: var(--btn-disabled-color);
      color: oklch( from var(--btn-text-color) l c h / 0.5 );
      cursor: not-allowed;
      transform: none;
      box-shadow: none;
    }
  }
  .btn-intent-primary {
    --btn-color: var(--color-brand-primary);
    --btn-text-color: oklch(
      from var(--btn-color) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
  }
  .btn-intent-secondary {
    --btn-color: oklch(
      from var(--color-brand-primary) calc(l + 0.40) calc(c * 0.1) h
    );
    --btn-text-color: var(--color-brand-primary);
    --btn-shadow: 0 1px 3px oklch(
      from var(--btn-color) l c h / 0.1
    );
    --btn-shadow-hover: 0 2px 6px oklch(
      from var(--btn-color) l c h / 0.15
    );
  }
  .btn-intent-success {
    --btn-color: var(--color-success);
    --btn-text-color: oklch(
      from var(--btn-color) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
  }
  .btn-intent-warning {
    --btn-color: var(--color-warning);
    --btn-text-color: oklch(
      from var(--btn-color) calc(l > 0.6 ? 0.15 : 0.85) c h
    );
  }
  .btn-intent-danger {
    --btn-color: var(--color-danger);
    --btn-text-color: oklch(
      from var(--btn-color) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
  }
  .btn-intent-info {
    --btn-color: var(--color-info);
    --btn-text-color: oklch(
      from var(--btn-color) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
  }
  .btn-style-ghost {
    --btn-color: transparent;
    --btn-text-color: var(--color-text-secondary);
    --btn-hover-color: oklch(
      from var(--color-brand-primary) l c h / 0.08
    );
    --btn-active-color: oklch(
      from var(--color-brand-primary) l c h / 0.12
    );
    --btn-shadow: none;
    --btn-shadow-hover: none;
    border: none;
  }
  .btn-style-outline {
    --btn-color: transparent;
    --btn-text-color: var(--color-brand-primary);
    --btn-hover-color: var(--color-brand-primary);
    --btn-hover-text-color: oklch(
      from var(--color-brand-primary) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
    --btn-shadow: none;
    --btn-shadow-hover: 0 2px 8px oklch(
      from var(--color-brand-primary) l c h / 0.15
    );
    border: 1px solid var(--color-brand-primary);
    &:hover:not(:disabled) {
      color: var(--btn-hover-text-color);
    }
  }
  .btn-style-link {
    --btn-color: transparent;
    --btn-text-color: var(--color-brand-primary);
    --btn-hover-color: transparent;
    --btn-hover-text-color: oklch(
      from var(--color-brand-primary) calc(l - 0.10) calc(c * 1.1) h
    );
    --btn-shadow: none;
    --btn-shadow-hover: none;
    background: transparent;
    border: none;
    padding: 0;
    text-decoration: underline;
    text-underline-offset: 0.125em;
    border-radius: 0;
    transform: none;
    &:hover:not(:disabled) {
      text-decoration: none;
      color: var(--btn-hover-text-color);
      transform: none;
    }
    &:focus-visible {
      outline: 2px solid var(--btn-focus-color);
      outline-offset: 2px;
      box-shadow: none;
    }
  }
  .btn-size-xs {
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    line-height: 1rem;
    border-radius: 0.25rem;
    --btn-shadow: 0 2px 6px oklch(
      from var(--btn-color) l c h / 0.1
    );
    --btn-shadow-hover: 0 3px 8px oklch(
      from var(--btn-color) l c h / 0.15
    );
  }
  .btn-size-sm {
    font-size: 0.875rem;
    line-height: 1.25rem;
    border-radius: 0.375rem;
    --btn-shadow: 0 3px 8px oklch(
      from var(--btn-color) l c h / 0.12
    );
    --btn-shadow-hover: 0 4px 10px oklch(
      from var(--btn-color) l c h / 0.16
    );
  }
  .btn-size-md {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    line-height: 1.25rem;
    border-radius: 0.375rem;
  }
  .btn-size-lg {
    padding: 0.75rem 1.5rem;
    font-size: 1rem;
    line-height: 1.5rem;
    border-radius: 0.5rem;
    --btn-shadow: 0 6px 16px oklch(
      from var(--btn-color) l c h / 0.18
    );
    --btn-shadow-hover: 0 8px 20px oklch(
      from var(--btn-color) l c h / 0.24
    );
  }
  .btn-size-xl {
    padding: 0.75rem 2rem;
    font-size: 1.125rem;
    line-height: 1.75rem;
    border-radius: 0.5rem;
    --btn-shadow: 0 8px 20px oklch(
      from var(--btn-color) l c h / 0.2
    );
    --btn-shadow-hover: 0 10px 24px oklch(
      from var(--btn-color) l c h / 0.26
    );
  }
  .btn-style-gradient {
    --btn-gradient-start: var(--btn-color);
    --btn-gradient-end: oklch(
      from var(--btn-color) calc(l + 0.10) c calc(h + 15)
    );
    --btn-hover-gradient-start: oklch(
      from var(--btn-gradient-start) calc(l - 0.05) calc(c * 1.1) h
    );
    --btn-hover-gradient-end: oklch(
      from var(--btn-gradient-end) calc(l - 0.05) calc(c * 1.1) h
    );
    background: linear-gradient( 135deg, var(--btn-gradient-start) 0%, var(--btn-gradient-end) 100% );
    border: none;
    &:hover:not(:disabled) {
      background: linear-gradient( 135deg, var(--btn-hover-gradient-start) 0%, var(--btn-hover-gradient-end) 100% );
    }
  }
  .btn-loading {
    position: relative;
    color: transparent;
    &::after {
      content: '';
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 1rem;
      height: 1rem;
      border: 2px solid oklch( from var(--btn-text-color) l c h / 0.3 );
      border-radius: 50%;
      border-top-color: var(--btn-text-color);
      animation: btn-spin 1s linear infinite;
    }
    &.btn-size-xs::after {
      width: 0.75rem;
      height: 0.75rem;
      border-width: 1px;
    }
    &.btn-size-sm::after {
      width: 0.875rem;
      height: 0.875rem;
      border-width: 1.5px;
    }
    &.btn-size-lg::after {
      width: 1.25rem;
      height: 1.25rem;
      border-width: 2.5px;
    }
    &.btn-size-xl::after {
      width: 1.5rem;
      height: 1.5rem;
      border-width: 3px;
    }
  }
  .btn-auto-contrast {
    --btn-text-color: oklch(
      from var(--btn-color) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
  }
  @media (prefers-contrast: high) {
    .btn-base {
      border-width: 2px;
      --btn-focus-color: oklch(
        from var(--btn-color) calc(l > 0.5 ? 0.20 : 0.80) calc(max(0.15, c)) calc(h + 180)
      );
    }
    .btn-style-outline {
      border-width: 3px;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .btn-base {
      transition: none;
    }
    .btn-loading::after {
      animation: none;
      border: 2px solid currentColor;
      border-radius: 0;
    }
  }
  .btn-group {
    display: inline-flex;
    border-radius: 0.375rem;
    overflow: hidden;
    box-shadow: 0 1px 3px oklch( from var(--color-brand-primary) l c h / 0.1 );
    .btn-base {
      border-radius: 0;
      border-right: 1px solid oklch( from var(--btn-color) calc(l - 0.15) c h );
      &:first-child {
        border-top-left-radius: 0.375rem;
        border-bottom-left-radius: 0.375rem;
      }
      &:last-child {
        border-top-right-radius: 0.375rem;
        border-bottom-right-radius: 0.375rem;
        border-right: 1px solid var(--btn-color);
      }
      &:focus {
        position: relative;
        z-index: 1;
      }
    }
  }
  @keyframes btn-spin {
    to {
      transform: translate(-50%, -50%) rotate(360deg);
    }
  }
  .btn-pulse {
    animation: btn-pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  }
  @keyframes btn-pulse {
    0%, 100% {
      opacity: 1;
      box-shadow: var(--btn-shadow);
    }
    50% {
      opacity: 0.8;
      box-shadow: var(--btn-shadow-hover);
    }
  }
  .btn-color-override {
    --btn-color: var(--color-override);
  }
  .btn-shadow-none {
    --btn-shadow: none;
    --btn-shadow-hover: none;
  }
  .btn-shadow-soft {
    --btn-shadow: 0 2px 8px oklch(
      from var(--btn-color) l c h / 0.08
    );
    --btn-shadow-hover: 0 4px 12px oklch(
      from var(--btn-color) l c h / 0.12
    );
  }
  .btn-shadow-hard {
    --btn-shadow: 0 4px 16px oklch(
      from var(--btn-color) l c h / 0.2
    );
    --btn-shadow-hover: 0 6px 20px oklch(
      from var(--btn-color) l c h / 0.26
    );
  }
}
.btn-dark {
  background: var(--token-neutral-900);
  color: var(--color-text-inverted-primary);
}
@layer components {
  a:hover {
    text-decoration: none;
  }
  .prose a:hover, .content a:hover {
    text-decoration: underline;
    text-decoration-color: var(--color-brand-secondary-muted, currentColor);
  }
  .link-base {
    --link-color: var(--color-brand-primary);
    --link-hover-color: oklch(from var(--link-color) calc(l - 0.1) c h);
    --link-visited-color: oklch(from var(--link-color) l c calc(h + 30));
    --link-active-color: oklch(from var(--link-color) calc(l - 0.2) c h);
    --link-underline-color: oklch(from var(--link-color) l c h / 0.3);
    --link-hover-underline-color: var(--link-hover-color);
    --link-focus-ring: oklch(from var(--link-color) l c h / 0.2);
    color: var(--link-color);
    text-decoration: underline;
    text-decoration-color: var(--link-underline-color);
    text-underline-offset: 2px;
    text-decoration-thickness: 1px;
    transition: all 200ms;
    cursor: pointer;
  }
  .link-base:hover {
    color: var(--link-hover-color);
    text-decoration-color: var(--link-hover-underline-color);
  }
  .link-base:visited {
    color: var(--link-visited-color);
  }
  .link-base:active {
    color: var(--link-active-color);
  }
  .link-base:focus-visible {
    outline: 2px solid var(--link-focus-ring);
    outline-offset: 2px;
    border-radius: 0.25rem;
  }
  .link-intent-primary {
    --link-color: var(--color-brand-primary);
    font-weight: 500;
  }
  .link-intent-secondary {
    --link-color: var(--color-text-secondary);
    --link-hover-color: var(--color-brand-primary);
  }
  .link-intent-muted {
    --link-color: var(--color-text-tertiary);
    --link-underline-color: transparent;
    --link-hover-color: var(--color-text-secondary);
    --link-hover-underline-color: var(--color-text-secondary);
  }
  .link-style-no-underline {
    text-decoration: none;
  }
  .link-style-no-underline:hover {
    text-decoration: underline;
    text-decoration-color: currentColor;
  }
  .link-style-hover-underline {
    text-decoration: none;
  }
  .link-style-hover-underline:hover {
    text-decoration: underline;
    text-decoration-color: currentColor;
  }
  .link-style-underline {
    text-decoration: underline;
    text-decoration-color: currentColor;
  }
  .link-style-animated {
    position: relative;
    text-decoration: none;
  }
  .link-style-animated::after {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 2px;
    background-color: currentColor;
    transition: width 200ms;
  }
  .link-style-animated:hover::after {
    width: 100%;
  }
  .link-state-icon {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
  }
  .link-state-icon svg {
    width: 1rem;
    height: 1rem;
    flex-shrink: 0;
  }
  .link-state-external::after {
    content: "";
    display: inline-block;
    width: 0.875rem;
    height: 0.875rem;
    margin-left: 0.25rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M10 6H6a2 2 0 00-2 2v10a2 2 0 002 2h10a2 2 0 002-2v-4M14 4h6m0 0v6m0-6L10 14'/%3E%3C/svg%3E");
    background-size: contain;
    background-repeat: no-repeat;
    opacity: 0.6;
    transition: opacity 200ms;
  }
  .link-state-external:hover::after {
    opacity: 1;
  }
  .link-state-arrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
  }
  .link-state-arrow::after {
    content: "→";
    transition: transform 200ms;
  }
  .link-state-arrow:hover::after {
    transform: translateX(0.25rem);
  }
  .link-state-arrow-left::before {
    content: "←";
    margin-right: 0.5rem;
    transition: transform 200ms;
  }
  .link-state-arrow-left::after {
    display: none;
  }
  .link-state-arrow-left:hover::before {
    transform: translateX(calc(0.25rem * -1));
  }
  .link-layout-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    font-weight: 500;
    text-decoration: none;
    background-color: oklch(from var(--link-color) l c h / 0.08);
    border-radius: 0.5rem;
    transition: all 200ms;
  }
  .link-layout-button:hover {
    background-color: oklch(from var(--link-color) l c h / 0.12);
    transform: translateY(-1px);
  }
  .link-layout-button:active {
    transform: translateY(0);
  }
  .link-layout-nav {
    display: inline-flex;
    align-items: center;
    padding: 0.5rem 0.75rem;
    color: var(--color-text-primary);
    text-decoration: none;
    font-weight: 500;
    border-radius: 0.375rem;
    transition: all 200ms;
  }
  .link-layout-nav:hover {
    color: var(--link-hover-color);
    background-color: oklch(from var(--link-hover-color) l c h / 0.08);
  }
  .link-layout-nav[aria-current="page"], .link-layout-nav.active {
    color: var(--link-color);
    background-color: oklch(from var(--link-color) l c h / 0.1);
  }
  .link-layout-breadcrumb {
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: 0.875rem;
  }
  .link-layout-breadcrumb:hover {
    color: var(--link-hover-color);
    text-decoration: underline;
  }
  .link-layout-breadcrumb[aria-current="page"] {
    color: var(--color-text-primary);
    pointer-events: none;
  }
  .link-layout-footer {
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: 0.875rem;
    transition: color 200ms;
  }
  .link-layout-footer:hover {
    color: var(--color-text-primary);
    text-decoration: underline;
  }
  .link-layout-card {
    --link-shadow: 0 4px 12px oklch(from var(--link-color) l c h / 0.08);
    --link-shadow-hover: 0 8px 24px oklch(from var(--link-color) l c h / 0.12);
    display: block;
    text-decoration: none;
    color: inherit;
    transition: all 200ms;
  }
  .link-layout-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--link-shadow-hover);
  }
  .link-layout-card:focus-visible {
    outline: 2px solid var(--link-focus-ring);
    outline-offset: 2px;
  }
  .link-state-skip {
    position: absolute;
    top: -100px;
    left: 1rem;
    z-index: 9999;
    padding: 0.75rem 1rem;
    background-color: var(--color-brand-primary);
    color: white;
    font-weight: 600;
    text-decoration: none;
    border-radius: 0.375rem;
    box-shadow: 0 4px 12px oklch(from var(--color-brand-primary) l c h / 0.3);
  }
  .link-state-skip:focus {
    top: 1rem;
  }
  .prose .link-base, .content .link-base {
    font-weight: 500;
  }
  @media (max-width: 40rem) {
    .link-state-icon svg {
      width: 0.875rem;
      height: 0.875rem;
    }
    .link-state-external::after {
      width: 0.75rem;
      height: 0.75rem;
    }
    .link-layout-button {
      padding: 0.375rem 0.75rem;
    }
  }
  @media (prefers-contrast: high) {
    .link-base, .link-intent-primary, .link-intent-secondary {
      text-decoration: underline;
      text-decoration-thickness: 2px;
      --link-underline-color: currentColor;
    }
    .link-layout-nav, .link-layout-breadcrumb {
      text-decoration: underline;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .link-base, .link-layout-button, .link-layout-nav, .link-layout-card {
      transition: none;
    }
    .link-style-animated::after {
      transition: none;
    }
    .link-state-arrow::after, .link-state-arrow-left::before {
      transition: none;
    }
    .link-state-arrow:hover::after, .link-state-arrow-left:hover::before, .link-layout-button:hover, .link-layout-card:hover {
      transform: none;
    }
  }
  @media print {
    .link-base {
      color: inherit;
      text-decoration: underline;
    }
    .link-state-external[href]::after {
      content: " (" attr(href) ")";
      font-size: 0.75rem;
      background-image: none;
      width: auto;
      height: auto;
    }
    .link-state-skip {
      display: none;
    }
    .link-layout-card {
      box-shadow: none;
    }
  }
}
@layer components {
  .card-base {
    --card-bg: var(--color-background-elevated);
    --card-border: var(--color-border-default);
    --card-text: var(--color-text-primary);
    --card-hover-bg: oklch(
      from var(--card-bg) calc(l - 0.02) c h
    );
    --card-hover-border: oklch(
      from var(--card-border) calc(l - 0.10) c h
    );
    --card-hover-shadow: oklch(
      from var(--color-brand-primary) l c h / 0.08
    );
    --card-shadow-base: 0 1px 3px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.1
    );
    --card-shadow-hover: 0 4px 12px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.15
    );
    --card-shadow-elevated: 0 10px 25px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.1
    );
    display: flex;
    flex-direction: column;
    position: relative;
    padding: 1.5rem;
    background-color: var(--card-bg);
    border: 1px solid var(--card-border);
    border-radius: 0.5rem;
    box-shadow: var(--card-shadow-base);
    color: var(--card-text);
    transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
  }
  .card-intent-content {
    --card-shadow-base: 0 2px 8px oklch(
      from var(--card-bg) calc(l - 0.35) c h / 0.08
    );
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  }
  .card-intent-navigation {
    cursor: pointer;
    --card-hover-bg: oklch(
      from var(--card-bg) calc(l - 0.03) calc(c + 0.05) h
    );
    --card-active-bg: oklch(
      from var(--card-bg) calc(l - 0.05) calc(c + 0.08) h
    );
    &:hover {
      background-color: var(--card-hover-bg);
      border-color: oklch( from var(--color-brand-primary) l c h / 0.3 );
      box-shadow: var(--card-shadow-hover), 0 0 0 1px var(--card-hover-shadow);
    }
    &:active {
      background-color: var(--card-active-bg);
      transform: translateY(-1px);
    }
    &:focus {
      outline: 2px solid transparent;
      outline-offset: 2px;
      box-shadow: 0 0 0 2px oklch( from var(--color-brand-primary) l c h / 0.5 );
    }
  }
  .card-intent-info {
    --card-bg: oklch(
      from var(--color-background-primary) calc(l - 0.01) calc(c + 0.02) h
    );
    --card-border: oklch(
      from var(--color-border-default) calc(l - 0.05) c h
    );
  }
  .card-intent-feature {
    --card-shadow-base: var(--card-shadow-elevated);
    --card-shadow-hover: 0 20px 40px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.15
    );
    --card-border: oklch(
      from var(--color-border-default) calc(l - 0.08) c h
    );
    &:hover {
      border-color: oklch( from var(--card-border) calc(l - 0.15) calc(c + 0.10) h );
      box-shadow: var(--card-shadow-hover);
    }
  }
  .card-branded {
    --card-accent: var(--color-brand-primary);
    --card-accent-subtle: oklch(
      from var(--card-accent) l c h / 0.05
    );
    --card-accent-border: oklch(
      from var(--card-accent) l c h / 0.12
    );
    --card-accent-hover: oklch(
      from var(--card-accent) calc(l - 0.05) calc(c * 1.1) h
    );
    background: linear-gradient( 135deg, var(--card-bg) 0%, var(--card-accent-subtle) 100% );
    border-left: 4px solid var(--card-accent);
    &:hover {
      border-left-color: var(--card-accent-hover);
      background: linear-gradient( 135deg, var(--card-hover-bg) 0%, oklch(from var(--card-accent) l c h / 0.08) 100% );
    }
  }
  .card-intent-success {
    --status-color: var(--color-success);
    --card-bg: oklch(
      from var(--status-color) calc(l + 0.35) calc(c * 0.3) h
    );
    --card-border: oklch(
      from var(--status-color) l c h / 0.2
    );
    border-left: 4px solid var(--status-color);
  }
  .card-intent-warning {
    --status-color: var(--color-warning);
    --card-bg: oklch(
      from var(--status-color) calc(l + 0.35) calc(c * 0.3) h
    );
    --card-border: oklch(
      from var(--status-color) l c h / 0.2
    );
    border-left: 4px solid var(--status-color);
  }
  .card-intent-error {
    --status-color: var(--color-danger);
    --card-bg: oklch(
      from var(--status-color) calc(l + 0.35) calc(c * 0.3) h
    );
    --card-border: oklch(
      from var(--status-color) l c h / 0.2
    );
    border-left: 4px solid var(--status-color);
  }
  .card-size-xs {
    padding: 0.75rem;
    border-radius: 0.375rem;
    --card-shadow-base: 0 1px 2px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.06
    );
    --card-shadow-hover: 0 2px 6px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.1
    );
  }
  .card-size-sm {
    padding: 1rem;
    border-radius: 0.375rem;
    --card-shadow-base: 0 1px 3px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.08
    );
    --card-shadow-hover: 0 3px 8px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.12
    );
  }
  .card-size-lg {
    padding: 2rem;
    border-radius: 0.5rem;
    --card-shadow-base: 0 4px 12px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.1
    );
    --card-shadow-hover: 0 12px 30px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.15
    );
  }
  .card-size-xl {
    padding: 2.5rem;
    border-radius: 0.75rem;
    --card-shadow-base: 0 6px 16px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.12
    );
    --card-shadow-hover: 0 16px 40px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.18
    );
  }
  .card-clickable {
    user-select: none;
    --card-pressed-bg: oklch(
      from var(--card-bg) calc(l - 0.04) c h
    );
    --card-pressed-shadow: 0 2px 6px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.2
    );
    &:hover {
      background-color: var(--card-hover-bg);
      border-color: var(--card-hover-border);
      box-shadow: var(--card-shadow-hover), 0 0 0 1px var(--card-hover-shadow);
    }
    &:active {
      background-color: var(--card-pressed-bg);
      box-shadow: var(--card-pressed-shadow);
    }
  }
  .card-selected {
    --selection-color: var(--color-brand-primary);
    --card-border: var(--selection-color);
    box-shadow: var(--card-shadow-base), 0 0 0 1px var(--selection-color), 0 0 0 3px oklch(from var(--selection-color) l c h / 0.1);
    &:hover {
      box-shadow: var(--card-shadow-hover), 0 0 0 1px var(--selection-color), 0 0 0 3px oklch(from var(--selection-color) l c h / 0.15);
    }
  }
  .card-loading {
    position: relative;
    overflow: hidden;
    &::before {
      content: '';
      position: absolute;
      top: 0;
      left: -100%;
      width: 100%;
      height: 2px;
      background: linear-gradient( 90deg, transparent, var(--color-brand-primary), transparent );
      animation: card-loading 2s infinite;
    }
    &::after {
      content: '';
      position: absolute;
      inset: 0;
      background: oklch( from var(--color-brand-primary) l c h / 0.02 );
      animation: card-pulse 3s ease-in-out infinite;
    }
  }
  @keyframes card-loading {
    0% {
      left: -100%;
    }
    100% {
      left: 100%;
    }
  }
  @keyframes card-pulse {
    0%, 100% {
      opacity: 0;
    }
    50% {
      opacity: 1;
    }
  }
  .card-header {
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid oklch( from var(--card-border) calc(l - 0.05) c h );
    .card-size-xs &, .card-size-sm & {
      margin-bottom: 0.75rem;
      padding-bottom: 0.5rem;
    }
    .card-size-lg &, .card-size-xl & {
      margin-bottom: 1.5rem;
      padding-bottom: 1rem;
    }
  }
  .card-title {
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1.75rem;
    margin: 0;
    color: oklch( from var(--card-text) calc(l > 0.5 ? calc(l - 0.10) : calc(l + 0.10)) c h );
    .card-size-xs & {
      font-size: 1rem;
      line-height: 1.5rem;
    }
    .card-size-lg &, .card-size-xl & {
      font-size: 1.25rem;
      line-height: 2rem;
    }
  }
  .card-description {
    font-size: 0.875rem;
    line-height: 1.5rem;
    color: oklch( from var(--card-text) calc(l > 0.5 ? calc(l + 0.15) : calc(l - 0.15)) calc(c * 0.8) h );
    .card-size-xs & {
      font-size: 0.75rem;
      line-height: 1.25rem;
    }
    .card-size-lg &, .card-size-xl & {
      font-size: 1rem;
      line-height: 1.75rem;
    }
  }
  .card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: oklch( from var(--card-text) calc(l > 0.5 ? calc(l + 0.25) : calc(l - 0.25)) calc(c * 0.6) h );
    .card-size-xs &, .card-size-sm & {
      gap: 0.5rem;
      font-size: 0.75rem;
    }
  }
  @media (prefers-contrast: high) {
    .card-base {
      border-width: 2px;
      --card-border: oklch(
        from var(--color-border-default) calc(l > 0.5 ? 0.20 : 0.80) c h
      );
    }
    .card-branded, .card-intent-success, .card-intent-warning, .card-intent-error {
      border-left-width: 6px;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .card-base {
      transition: none;
    }
    .card-base:hover, .card-clickable:hover, .card-intent-navigation:hover, .card-intent-feature:hover {
      transform: none;
    }
    .card-loading::before, .card-loading::after {
      animation: none;
    }
  }
  .card-adaptive {
    --context-color: var(--parent-context-color, var(--color-brand-primary));
    --card-accent: var(--context-color);
    --card-hover-shadow: oklch(
      from var(--context-color) l c h / 0.1
    );
  }
  .card-theme-warm {
    --card-bg: oklch(
      from var(--color-background-primary) calc(l - 0.01) calc(c + 0.05) calc(h + 10)
    );
  }
  .card-theme-cool {
    --card-bg: oklch(
      from var(--color-background-primary) calc(l - 0.01) calc(c + 0.03) calc(h - 10)
    );
  }
  .card-bg-override {
    --card-bg: var(--bg-override);
  }
  .card-border-override {
    --card-border: var(--border-override);
  }
  .card-shadow-none {
    --card-shadow-base: none;
    --card-shadow-hover: none;
  }
  .card-shadow-soft {
    --card-shadow-base: 0 1px 3px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.06
    );
    --card-shadow-hover: 0 3px 8px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.1
    );
  }
  .card-shadow-dramatic {
    --card-shadow-base: 0 8px 25px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.15
    );
    --card-shadow-hover: 0 20px 50px oklch(
      from var(--card-bg) calc(l - 0.40) c h / 0.2
    );
  }
  .card-header {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--color-border-subtle);
    margin-bottom: 1rem;
  }
  .card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }
  .card-footer {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding-top: 1rem;
    border-top: 1px solid var(--color-border-subtle);
    margin-top: 1rem;
  }
  .card-title {
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.25;
    color: var(--color-text-primary);
    margin: 0;
  }
  .card-description {
    font-size: 0.875rem;
    line-height: 1.625;
    color: var(--color-text-secondary);
    margin: 0;
  }
  .card-actions {
    display: flex;
    gap: 0.5rem;
    align-items: center;
  }
  .card-actions-between {
    justify-content: space-between;
  }
  .card-actions-center {
    justify-content: center;
  }
  .card-actions-end {
    justify-content: flex-end;
  }
  .card-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.875rem;
    color: var(--color-text-secondary);
  }
  .card-meta-item {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
  }
  .card-size-xs .card-title {
    font-size: 1.125rem;
  }
  .card-size-sm .card-title {
    font-size: 1.125rem;
    padding-top: 0.5rem;
  }
  .card-size-lg .card-title {
    font-size: 1.5rem;
  }
  .card-size-xl .card-title {
    font-size: 1.875rem;
  }
}
@layer components {
  .form-group {
    margin-bottom: var(--spacing-component-lg, 1.5rem);
    &.has-error {
      --error-color: var(--color-danger);
      --error-bg: oklch(from var(--error-color) calc(l + 0.35) calc(c * 0.3) h);
      --error-border: oklch(from var(--error-color) calc(l + 0.05) calc(c * 0.8) h);
      --error-shadow: oklch(from var(--error-color) l c h / 0.15);
      --error-shadow-focus: oklch(from var(--error-color) l c h / 0.25);
      .form-label {
        color: oklch(from var(--error-color) calc(l - 0.05) calc(c * 1.1) h);
      }
      .form-input, .form-textarea, .form-select {
        background-color: var(--error-bg);
        border-color: var(--error-border);
        box-shadow: 0 0 0 3px var(--error-shadow);
        &:focus {
          border-color: var(--error-color);
          box-shadow: 0 0 0 3px var(--error-shadow-focus);
          background-color: oklch(from var(--error-bg) calc(l + 0.02) calc(c * 1.1) h);
        }
        &:hover:not(:focus) {
          border-color: oklch(from var(--error-border) calc(l - 0.05) calc(c * 1.1) h);
        }
      }
    }
    &.has-success {
      --success-color: var(--color-success);
      --success-bg: oklch(from var(--success-color) calc(l + 0.35) calc(c * 0.3) h);
      --success-border: oklch(from var(--success-color) calc(l + 0.05) calc(c * 0.8) h);
      --success-shadow: oklch(from var(--success-color) l c h / 0.15);
      --success-shadow-focus: oklch(from var(--success-color) l c h / 0.25);
      .form-label {
        color: oklch(from var(--success-color) calc(l - 0.05) calc(c * 1.1) h);
      }
      .form-input, .form-textarea, .form-select {
        background-color: var(--success-bg);
        border-color: var(--success-border);
        box-shadow: 0 0 0 3px var(--success-shadow);
        &:focus {
          border-color: var(--success-color);
          box-shadow: 0 0 0 3px var(--success-shadow-focus);
          background-color: oklch(from var(--success-bg) calc(l + 0.02) calc(c * 1.1) h);
        }
      }
    }
    &.has-warning {
      --warning-color: var(--color-warning);
      --warning-bg: oklch(from var(--warning-color) calc(l + 0.3) calc(c * 0.3) h);
      --warning-border: oklch(from var(--warning-color) calc(l + 0.05) calc(c * 0.8) h);
      --warning-shadow: oklch(from var(--warning-color) l c h / 0.15);
      .form-label {
        color: oklch(from var(--warning-color) calc(l - 0.1) calc(c * 1.2) h);
      }
      .form-input, .form-textarea, .form-select {
        background-color: var(--warning-bg);
        border-color: var(--warning-border);
        box-shadow: 0 0 0 3px var(--warning-shadow);
      }
    }
  }
  .form-label {
    display: block;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-component-sm, 0.5rem);
    font-size: 0.875rem;
    line-height: 1.25;
    transition: color 150ms ease-out;
    color: oklch(from var(--color-background-primary) calc(l > 0.5 ? 0.25 : 0.85) c h);
    &.required::after {
      content: " *";
      color: var(--color-danger);
      transition: color 150ms ease-out;
    }
    .form-group:focus-within & {
      color: oklch(from var(--color-brand-primary) calc(l - 0.1) calc(c * 1.1) h);
    }
  }
  .form-label-inline {
    display: inline-block;
    margin-bottom: 0;
    margin-right: var(--spacing-component-md, 1rem);
    font-weight: 400;
  }
  .form-input, .form-textarea, .form-select {
    --input-bg: var(--color-background-primary);
    --input-border: var(--color-border-default);
    --input-text: var(--color-text-primary);
    --input-placeholder: var(--color-text-tertiary);
    --input-hover-border: oklch(from var(--input-border) calc(l - 0.1) calc(c * 1.2) h);
    --input-focus-border: var(--color-brand-primary);
    --input-focus-bg: oklch(from var(--input-bg) calc(l + 0.01) calc(c + 0.02) h);
    --input-focus-shadow: oklch(from var(--input-focus-border) l c h / 0.15);
    --input-focus-shadow-ring: oklch(from var(--input-focus-border) l c h / 0.1);
    --input-disabled-bg: oklch(from var(--input-bg) calc(l - 0.05) calc(c * 0.3) h);
    --input-disabled-border: oklch(from var(--input-border) calc(l + 0.1) calc(c * 0.5) h);
    --input-disabled-text: oklch(from var(--input-text) calc(l + 0.2) calc(c * 0.4) h);
    width: 100%;
    padding: var(--spacing-component-sm, 0.5rem) var(--spacing-component-md, 1rem);
    border: 1px solid var(--input-border);
    border-radius: var(--radius-sm, 0.375rem);
    font-size: 1rem;
    font-family: inherit;
    line-height: 1.5rem;
    background-color: var(--input-bg);
    color: var(--input-text);
    transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
    &:hover:not(:disabled):not(:focus) {
      border-color: var(--input-hover-border);
      background-color: oklch(from var(--input-bg) calc(l - 0.005) calc(c + 0.01) h);
    }
    &:focus {
      outline: none;
      border-color: var(--input-focus-border);
      background-color: var(--input-focus-bg);
      box-shadow: 0 0 0 3px var(--input-focus-shadow), 0 1px 3px var(--input-focus-shadow-ring);
      transform: translateY(-1px);
    }
    &:disabled {
      background-color: var(--input-disabled-bg);
      color: var(--input-disabled-text);
      cursor: not-allowed;
      border-color: var(--input-disabled-border);
      opacity: 0.7;
    }
    &::placeholder {
      color: var(--input-placeholder);
      transition: color 150ms ease-out;
    }
    &:focus::placeholder {
      color: oklch(from var(--input-placeholder) calc(l + 0.1) calc(c * 0.8) h);
    }
  }
  .form-input-sm, .form-textarea-sm, .form-select-sm {
    padding: 0.25rem var(--spacing-component-sm, 0.5rem);
    font-size: 0.875rem;
    height: var(--form-element-height-sm, 2rem);
    border-radius: var(--radius-xs, 0.25rem);
    &:focus {
      box-shadow: 0 0 0 2px var(--input-focus-shadow), 0 1px 2px var(--input-focus-shadow-ring);
      transform: translateY(-0.5px);
    }
  }
  .form-input-lg, .form-textarea-lg, .form-select-lg {
    padding: var(--spacing-component-md, 1rem) var(--spacing-component-lg, 1.5rem);
    font-size: 1.125rem;
    height: var(--form-element-height-lg, 3rem);
    border-radius: var(--radius-md, 0.5rem);
    &:focus {
      box-shadow: 0 0 0 4px var(--input-focus-shadow), 0 2px 6px var(--input-focus-shadow-ring);
      transform: translateY(-2px);
    }
  }
  .form-textarea {
    resize: vertical;
    min-height: 5rem;
    line-height: 1.625;
    &::-webkit-scrollbar {
      width: 8px;
    }
    &::-webkit-scrollbar-track {
      background: oklch(from var(--input-bg) calc(l - 0.05) c h);
      border-radius: 0.25rem;
    }
    &::-webkit-scrollbar-thumb {
      background: oklch(from var(--input-border) calc(l - 0.1) c h);
      border-radius: 0.25rem;
    }
    &::-webkit-scrollbar-thumb:hover {
      background: oklch(from var(--input-border) calc(l - 0.2) c h);
    }
  }
  .form-textarea-sm {
    min-height: 4rem;
  }
  .form-textarea-lg {
    min-height: 6rem;
  }
  .form-select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 2rem;
    appearance: none;
    cursor: pointer;
    &:hover:not(:disabled) {
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23374151' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
    }
    &:focus {
      background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%232563eb' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");
    }
  }
  .form-checkbox, .form-radio {
    --control-bg: var(--color-background-primary);
    --control-border: var(--color-border-default);
    --control-checked-bg: var(--color-brand-primary);
    --control-checked-border: var(--control-checked-bg);
    --control-focus-shadow: oklch(from var(--control-checked-bg) l c h / 0.25);
    --control-hover-border: oklch(from var(--control-border) calc(l - 0.15) calc(c * 1.2) h);
    --control-hover-bg: oklch(from var(--control-bg) calc(l - 0.02) calc(c + 0.02) h);
    width: 1rem;
    height: 1rem;
    border: 1px solid var(--control-border);
    background-color: var(--control-bg);
    margin-right: var(--spacing-component-sm, 0.5rem);
    flex-shrink: 0;
    cursor: pointer;
    transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
    &:hover:not(:disabled) {
      border-color: var(--control-hover-border);
      background-color: var(--control-hover-bg);
      transform: scale(1.05);
    }
    &:checked {
      background-color: var(--control-checked-bg);
      border-color: var(--control-checked-border);
      box-shadow: 0 1px 3px oklch(from var(--control-checked-bg) l c h / 0.2);
    }
    &:focus {
      outline: none;
      box-shadow: 0 0 0 3px var(--control-focus-shadow);
    }
    &:disabled {
      opacity: 0.5;
      cursor: not-allowed;
      transform: none;
    }
  }
  .form-checkbox {
    border-radius: var(--radius-sm, 0.375rem);
  }
  .form-radio {
    border-radius: 9999px;
  }
  .input-group {
    display: flex;
    .input-group-text {
      --group-bg: oklch(from var(--color-background-primary) calc(l - 0.03) calc(c + 0.03) h);
      --group-border: var(--color-border-default);
      --group-text: oklch(from var(--color-text-primary) calc(l + 0.1) calc(c * 0.8) h);
      background-color: var(--group-bg);
      border: 1px solid var(--group-border);
      border-right: 0;
      color: var(--group-text);
      font-size: 0.875rem;
      font-weight: 500;
      padding: var(--spacing-component-sm, 0.5rem) var(--spacing-component-md, 1rem);
      border-radius: var(--radius-sm, 0.375rem) 0 0 var(--radius-sm, 0.375rem);
      white-space: nowrap;
      transition: all 150ms ease-out;
    }
    .form-input {
      border-radius: 0 var(--radius-sm, 0.375rem) var(--radius-sm, 0.375rem) 0;
      border-left: 0;
      &:focus {
        z-index: 2;
        border-color: var(--input-focus-border);
        box-shadow: 0 0 0 3px var(--input-focus-shadow), inset 1px 0 0 var(--input-focus-border);
      }
    }
    &:focus-within .input-group-text {
      border-color: var(--input-focus-border);
      background-color: oklch(from var(--group-bg) calc(l - 0.02) calc(c + 0.05) h);
    }
  }
  .form-file {
    position: relative;
    display: inline-block;
    input[type="file"] {
      position: absolute;
      opacity: 0;
      width: 100%;
      height: 100%;
      cursor: pointer;
    }
    .form-file-label {
      --file-bg: oklch(from var(--color-background-primary) calc(l - 0.02) calc(c + 0.02) h);
      --file-border: var(--color-border-default);
      --file-hover-bg: oklch(from var(--file-bg) calc(l - 0.05) calc(c + 0.05) h);
      --file-hover-border: oklch(from var(--file-border) calc(l - 0.1) calc(c * 1.2) h);
      display: inline-block;
      padding: var(--spacing-component-sm, 0.5rem) var(--spacing-component-md, 1rem);
      background-color: var(--file-bg);
      border: 1px solid var(--file-border);
      border-radius: var(--radius-sm, 0.375rem);
      color: var(--color-text-primary);
      font-size: 0.875rem;
      font-weight: 500;
      cursor: pointer;
      transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
      &:hover {
        background-color: var(--file-hover-bg);
        border-color: var(--file-hover-border);
        transform: translateY(-1px);
        box-shadow: 0 2px 4px oklch(from var(--file-bg) calc(l - 0.2) c h / 0.1);
      }
      &:focus-within {
        outline: 2px solid var(--input-focus-shadow);
        outline-offset: 2px;
      }
    }
  }
  .form-help {
    font-size: 0.875rem;
    color: oklch(from var(--color-text-primary) calc(l + 0.25) calc(c * 0.6) h);
    margin-top: var(--spacing-component-sm, 0.5rem);
    line-height: 1.625;
    transition: color 150ms ease-out;
  }
  .form-error {
    font-size: 0.875rem;
    color: oklch(from var(--color-danger) calc(l - 0.05) calc(c * 1.1) h);
    margin-top: var(--spacing-component-sm, 0.5rem);
    line-height: 1.625;
    animation: form-message-slide-in 200ms ease-out;
    &::before {
      content: "⚠ ";
      font-weight: 700;
      color: var(--color-danger);
    }
  }
  .form-success {
    font-size: 0.875rem;
    color: oklch(from var(--color-success) calc(l - 0.05) calc(c * 1.1) h);
    margin-top: var(--spacing-component-sm, 0.5rem);
    line-height: 1.625;
    animation: form-message-slide-in 200ms ease-out;
    &::before {
      content: "✓ ";
      font-weight: 700;
      color: var(--color-success);
    }
  }
  @keyframes form-message-slide-in {
    from {
      opacity: 0;
      transform: translateY(-4px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
  .form-row {
    display: flex;
    gap: var(--spacing-component-md, 1rem);
    margin-bottom: var(--spacing-component-lg, 1.5rem);
    .form-group {
      flex: 1;
      margin-bottom: 0;
    }
    @media (max-width: 40rem) {
      flex-direction: column;
      gap: 0;
      .form-group {
        margin-bottom: var(--spacing-component-lg, 1.5rem);
      }
    }
  }
  .form-inline {
    display: flex;
    align-items: center;
    gap: var(--spacing-component-md, 1rem);
    margin-bottom: var(--spacing-component-lg, 1.5rem);
    .form-group {
      margin-bottom: 0;
    }
    .form-label {
      margin-bottom: 0;
      white-space: nowrap;
    }
  }
  @media (prefers-contrast: high) {
    .form-input, .form-textarea, .form-select {
      border-width: 2px;
      &:focus {
        outline: 3px solid var(--input-focus-border);
        outline-offset: 2px;
      }
    }
    .form-checkbox, .form-radio {
      border-width: 2px;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .form-input, .form-textarea, .form-select, .form-checkbox, .form-radio, .form-file-label {
      transition: none;
    }
    .form-input:focus, .form-textarea:focus, .form-select:focus {
      transform: none;
    }
    .form-message-slide-in {
      animation: none;
    }
  }
  .form-input-brand {
    --input-focus-border: var(--color-brand-primary);
  }
  .form-input-success {
    --input-focus-border: var(--color-success);
  }
  .form-input-warning {
    --input-focus-border: var(--color-warning);
  }
  .form-input-danger {
    --input-focus-border: var(--color-danger);
  }
  .form-input-xs {
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    height: 1.5rem;
  }
  .form-input-2xl {
    padding: 1.25rem 2rem;
    font-size: 1.25rem;
    height: 4rem;
  }
}
@layer components {
  .modal-overlay {
    --overlay-base: var(--color-background-primary);
    --overlay-backdrop: oklch(
      from var(--overlay-base) calc(l > 0.5 ? calc(l - 0.4) : calc(l + 0.4)) c h / 0.6
    );
    --overlay-backdrop-blur: oklch(
      from var(--overlay-base) calc(l > 0.5 ? calc(l - 0.3) : calc(l + 0.3)) c h / 0.8
    );
    position: fixed;
    inset: 0;
    z-index: 50;
    background: var(--overlay-backdrop);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    opacity: 0;
    visibility: hidden;
    &.modal-open {
      opacity: 1;
      visibility: visible;
    }
    &.modal-backdrop-heavy {
      --overlay-backdrop: oklch(
        from var(--overlay-base) calc(l > 0.5 ? calc(l - 0.5) : calc(l + 0.5)) c h / 0.8
      );
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
    }
  }
  .modal-container {
    position: fixed;
    inset: 0;
    z-index: 51;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    @media (min-width: 40rem) {
      padding: 1.5rem;
    }
    @media (min-width: 64rem) {
      padding: 2rem;
    }
  }
  .modal-content {
    --modal-bg: var(--color-background-elevated);
    --modal-border: var(--color-border-default);
    --modal-text: var(--color-text-primary);
    --modal-shadow: 0 20px 50px oklch(
      from var(--modal-bg) calc(l - 0.4) c h / 0.15
    );
    --modal-shadow-dramatic: 0 25px 60px oklch(
      from var(--modal-bg) calc(l - 0.45) c h / 0.2
    );
    position: relative;
    width: 100%;
    max-width: 32rem;
    max-height: calc(100vh - 2rem);
    overflow: hidden;
    background: var(--modal-bg);
    border: 1px solid var(--modal-border);
    border-radius: 0.75rem;
    box-shadow: var(--modal-shadow);
    color: var(--modal-text);
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    transform: scale(0.95) translateY(-20px);
    opacity: 0;
    .modal-open & {
      transform: scale(1) translateY(0);
      opacity: 1;
    }
    @media (max-width: 40rem) {
      max-width: calc(100vw - 1rem);
      margin: 0.5rem;
    }
  }
  .modal-size-xs {
    max-width: 24rem;
    .modal-content {
      --modal-shadow: 0 10px 25px oklch(
        from var(--modal-bg) calc(l - 0.35) c h / 0.12
      );
    }
  }
  .modal-size-sm {
    max-width: 28rem;
    .modal-content {
      --modal-shadow: 0 15px 35px oklch(
        from var(--modal-bg) calc(l - 0.38) c h / 0.13
      );
    }
  }
  .modal-size-lg {
    max-width: 42rem;
    .modal-content {
      --modal-shadow: var(--modal-shadow-dramatic);
    }
  }
  .modal-size-xl {
    max-width: 56rem;
    .modal-content {
      --modal-shadow: 0 30px 70px oklch(
        from var(--modal-bg) calc(l - 0.5) c h / 0.25
      );
    }
  }
  .modal-size-full {
    .modal-content {
      max-width: calc(100vw - 2rem);
      max-height: calc(100vh - 2rem);
      --modal-shadow: 0 35px 80px oklch(
        from var(--modal-bg) calc(l - 0.55) c h / 0.3
      );
    }
  }
  .modal-header {
    --header-border: oklch(
      from var(--modal-border) calc(l - 0.05) c h
    );
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.5rem 1.5rem 1rem;
    border-bottom: 1px solid var(--header-border);
    @media (max-width: 40rem) {
      padding: 1rem 1rem 0.75rem;
    }
  }
  .modal-title {
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.75rem;
    margin: 0;
    color: oklch( from var(--modal-text) calc(l - 0.1) calc(c * 1.1) h );
    @media (max-width: 40rem) {
      font-size: 1.125rem;
      line-height: 1.5rem;
    }
  }
  .modal-subtitle {
    font-size: 0.875rem;
    color: oklch( from var(--modal-text) calc(l + 0.15) calc(c * 0.8) h );
    margin: 0.25rem 0 0;
  }
  .modal-body {
    padding: 1.5rem;
    overflow-y: auto;
    max-height: calc(100vh - 8rem);
    @media (max-width: 40rem) {
      padding: 1rem;
    }
    &::-webkit-scrollbar {
      width: 8px;
    }
    &::-webkit-scrollbar-track {
      background: oklch(from var(--modal-bg) calc(l - 0.05) c h);
      border-radius: 0.25rem;
    }
    &::-webkit-scrollbar-thumb {
      background: oklch(from var(--modal-border) calc(l - 0.1) c h);
      border-radius: 0.25rem;
    }
    &::-webkit-scrollbar-thumb:hover {
      background: oklch(from var(--modal-border) calc(l - 0.2) c h);
    }
  }
  .modal-body > * + * {
    margin-top: 1rem;
  }
  .modal-body > h1, .modal-body > h2, .modal-body > h3, .modal-body > h4, .modal-body > h5, .modal-body > h6 {
    color: oklch( from var(--modal-text) calc(l - 0.05) calc(c * 1.1) h );
  }
  .modal-footer {
    --footer-border: oklch(
      from var(--modal-border) calc(l - 0.05) c h
    );
    --footer-bg: oklch(
      from var(--modal-bg) calc(l - 0.01) calc(c + 0.02) h
    );
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.75rem;
    padding: 1rem 1.5rem;
    border-top: 1px solid var(--footer-border);
    background: var(--footer-bg);
    border-radius: 0 0 0.75rem 0.75rem;
    @media (max-width: 40rem) {
      padding: 0.75rem 1rem;
      flex-direction: column-reverse;
      gap: 0.5rem;
    }
    &.modal-footer-between {
      justify-content: space-between;
    }
    &.modal-footer-center {
      justify-content: center;
    }
    &.modal-footer-start {
      justify-content: flex-start;
    }
  }
  .modal-close {
    --close-color: oklch(
      from var(--modal-text) calc(l + 0.2) calc(c * 0.8) h
    );
    --close-hover-color: oklch(
      from var(--modal-text) calc(l - 0.1) calc(c * 1.2) h
    );
    --close-hover-bg: oklch(
      from var(--modal-bg) calc(l - 0.05) calc(c + 0.05) h
    );
    --close-focus-ring: oklch(
      from var(--color-brand-primary) l c h / 0.3
    );
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 2rem;
    height: 2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.375rem;
    color: var(--close-color);
    cursor: pointer;
    transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
    border: none;
    background: transparent;
    &:hover {
      color: var(--close-hover-color);
      background: var(--close-hover-bg);
      transform: scale(1.05);
    }
    &:focus-visible {
      outline: 2px solid var(--close-focus-ring);
      outline-offset: 2px;
    }
    &:active {
      transform: scale(0.95);
    }
    @media (max-width: 40rem) {
      top: 0.75rem;
      right: 0.75rem;
      width: 1.75rem;
      height: 1.75rem;
    }
  }
  .modal-intent-success {
    .modal-content {
      --modal-accent: var(--color-success);
      border-top: 4px solid var(--modal-accent);
      --modal-shadow: 0 20px 50px oklch(
        from var(--modal-accent) l c h / 0.1
      );
    }
    .modal-header {
      background: oklch( from var(--modal-accent) calc(l + 0.4) calc(c * 0.2) h );
    }
    .modal-title {
      color: oklch( from var(--modal-accent) calc(l - 0.15) calc(c * 1.1) h );
    }
  }
  .modal-intent-warning {
    .modal-content {
      --modal-accent: var(--color-warning);
      border-top: 4px solid var(--modal-accent);
      --modal-shadow: 0 20px 50px oklch(
        from var(--modal-accent) l c h / 0.1
      );
    }
    .modal-header {
      background: oklch( from var(--modal-accent) calc(l + 0.35) calc(c * 0.2) h );
    }
    .modal-title {
      color: oklch( from var(--modal-accent) calc(l - 0.25) calc(c * 1.2) h );
    }
  }
  .modal-intent-danger {
    .modal-content {
      --modal-accent: var(--color-danger);
      border-top: 4px solid var(--modal-accent);
      --modal-shadow: 0 20px 50px oklch(
        from var(--modal-accent) l c h / 0.1
      );
    }
    .modal-header {
      background: oklch( from var(--modal-accent) calc(l + 0.4) calc(c * 0.2) h );
    }
    .modal-title {
      color: oklch( from var(--modal-accent) calc(l - 0.15) calc(c * 1.1) h );
    }
  }
  .modal-intent-info {
    .modal-content {
      --modal-accent: var(--color-info);
      border-top: 4px solid var(--modal-accent);
      --modal-shadow: 0 20px 50px oklch(
        from var(--modal-accent) l c h / 0.1
      );
    }
    .modal-header {
      background: oklch( from var(--modal-accent) calc(l + 0.4) calc(c * 0.2) h );
    }
    .modal-title {
      color: oklch( from var(--modal-accent) calc(l - 0.15) calc(c * 1.1) h );
    }
  }
  .modal-centered {
    .modal-container {
      align-items: center;
    }
  }
  .modal-bottom-sheet {
    .modal-container {
      align-items: flex-end;
      padding-bottom: 0;
    }
    .modal-content {
      border-radius: 0.75rem 0.75rem 0 0;
      max-height: 80vh;
      transform: translateY(100%);
      .modal-open & {
        transform: translateY(0);
      }
    }
  }
  .modal-slide-right {
    .modal-container {
      justify-content: flex-end;
      align-items: stretch;
      padding: 0;
    }
    .modal-content {
      max-width: 28rem;
      height: 100vh;
      border-radius: 0;
      transform: translateX(100%);
      .modal-open & {
        transform: translateX(0);
      }
    }
  }
  .modal-fullscreen {
    .modal-container {
      padding: 0;
    }
    .modal-content {
      width: 100vw;
      height: 100vh;
      max-width: none;
      max-height: none;
      border-radius: 0;
      border: none;
    }
  }
  .modal-anim-fade-up {
    .modal-content {
      transform: scale(0.9) translateY(20px);
      .modal-open & {
        transform: scale(1) translateY(0);
      }
    }
  }
  .modal-anim-zoom {
    .modal-content {
      transform: scale(0.8);
      .modal-open & {
        transform: scale(1);
      }
    }
  }
  .modal-anim-slide-down {
    .modal-content {
      transform: translateY(-50px);
      .modal-open & {
        transform: translateY(0);
      }
    }
  }
  @media (prefers-contrast: high) {
    .modal-content {
      border-width: 2px;
      --modal-border: oklch(
        from var(--color-border-default) calc(l > 0.5 ? 0.2 : 0.8) c h
      );
    }
    .modal-close {
      border: 2px solid var(--close-color);
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .modal-overlay, .modal-content, .modal-close {
      transition: none;
    }
    .modal-content {
      transform: none;
    }
    .modal-open .modal-content {
      transform: none;
    }
  }
  .modal-focus-trap {
    outline: 2px solid transparent;
    outline-offset: -2px;
  }
  .modal-focus-trap:focus-within {
    outline-color: oklch( from var(--color-brand-primary) l c h / 0.5 );
  }
  .modal-backdrop-light {
    --overlay-backdrop: oklch(
      from var(--overlay-base) calc(l - 0.2) c h / 0.4
    );
  }
  .modal-backdrop-heavy {
    --overlay-backdrop: oklch(
      from var(--overlay-base) calc(l - 0.6) c h / 0.9
    );
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
  }
  .modal-shadow-none {
    --modal-shadow: none;
  }
  .modal-shadow-soft {
    --modal-shadow: 0 10px 25px oklch(
      from var(--modal-bg) calc(l - 0.3) c h / 0.08
    );
  }
  .modal-shadow-dramatic {
    --modal-shadow: 0 35px 80px oklch(
      from var(--modal-bg) calc(l - 0.5) c h / 0.3
    );
  }
  .modal-compact {
    .modal-header, .modal-body, .modal-footer {
      padding: 1rem;
    }
  }
  .modal-spacious {
    .modal-header, .modal-body, .modal-footer {
      padding: 2rem;
    }
  }
  .modal-loading {
    .modal-content {
      position: relative;
      overflow: hidden;
    }
    .modal-content::before {
      content: '';
      position: absolute;
      top: 0;
      left: -100%;
      width: 100%;
      height: 2px;
      background: linear-gradient( 90deg, transparent, var(--color-brand-primary), transparent );
      animation: modal-loading 2s infinite;
      z-index: 1;
    }
  }
  @keyframes modal-loading {
    0% {
      left: -100%;
    }
    100% {
      left: 100%;
    }
  }
  .modal-shimmer {
    .modal-body {
      background: linear-gradient( 90deg, var(--modal-bg) 25%, oklch(from var(--modal-bg) calc(l - 0.03) c h) 50%, var(--modal-bg) 75% );
      background-size: 200% 100%;
      animation: modal-shimmer 1.5s infinite;
    }
  }
  @keyframes modal-shimmer {
    0% {
      background-position: -200% 0;
    }
    100% {
      background-position: 200% 0;
    }
  }
}
@layer components {
  .nav-container {
    --nav-bg: var(--color-background-primary);
    --nav-border: var(--color-border-default);
    --nav-backdrop: oklch(from var(--nav-bg) l c h / 0.95);
    background-color: var(--nav-backdrop);
    border-bottom: 1px solid var(--nav-border);
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 1px 3px oklch(from var(--nav-bg) calc(l - 0.2) c h / 0.1);
    &.nav-scrolled {
      --nav-backdrop: oklch(from var(--nav-bg) l c h / 0.98);
      box-shadow: 0 4px 12px oklch(from var(--nav-bg) calc(l - 0.3) c h / 0.15);
    }
  }
  .nav-wrapper {
    max-width: 72rem;
    margin-left: auto;
    margin-right: auto;
    padding-left: 1rem;
    padding-right: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 4rem;
    @media (min-width: 40rem) {
      padding-left: 1.5rem;
      padding-right: 1.5rem;
    }
    @media (min-width: 64rem) {
      padding-left: 2rem;
      padding-right: 2rem;
    }
  }
  .nav-brand {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  .nav-logo {
    --logo-color: var(--color-text-primary);
    --logo-hover-color: oklch(from var(--color-brand-primary) calc(l - 0.05) calc(c * 1.1) h);
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--logo-color);
    text-decoration: none;
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: 0.375rem;
    padding: 0.25rem 0.5rem;
    &:hover {
      color: var(--logo-hover-color);
      transform: translateY(-1px);
      text-shadow: 0 2px 4px oklch(from var(--logo-hover-color) l c h / 0.2);
    }
    &:focus-visible {
      outline: 2px solid oklch(from var(--color-brand-primary) l c h / 0.5);
      outline-offset: 2px;
    }
  }
  .nav-logo-part-1 {
    --part1-color: oklch(from var(--logo-color) calc(l + 0.15) calc(c * 0.8) h);
    color: var(--part1-color);
    transition: color 300ms cubic-bezier(0.4, 0, 0.2, 1);
  }
  .nav-logo-part-2 {
    --part2-color: oklch(from var(--logo-color) calc(l - 0.1) calc(c * 1.1) h);
    color: var(--part2-color);
    margin-left: -0.1em;
    transition: color 300ms cubic-bezier(0.4, 0, 0.2, 1);
  }
  .nav-logo:hover .nav-logo-part-1 {
    color: oklch(from var(--color-warning) calc(l - 0.05) calc(c * 1.1) h);
  }
  .nav-logo:hover .nav-logo-part-2 {
    color: oklch(from var(--color-info) calc(l - 0.05) calc(c * 1.1) h);
  }
  .nav-main {
    display: none;
    @media (min-width: 48rem) {
      display: flex;
      gap: 1.5rem;
    }
  }
  .nav-link {
    --link-color: var(--color-text-secondary);
    --link-hover-color: oklch(from var(--color-brand-primary) calc(l - 0.05) calc(c * 1.05) h);
    --link-active-color: var(--color-brand-primary);
    --link-border-hover: oklch(from var(--link-hover-color) calc(l + 0.2) calc(c * 0.6) h);
    --link-bg-hover: oklch(from var(--link-hover-color) l c h / 0.05);
    color: var(--link-color);
    text-decoration: none;
    padding: 0.5rem 0.75rem;
    border-bottom: 2px solid transparent;
    border-radius: 0.375rem 0.375rem 0 0;
    transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
    font-weight: 500;
    position: relative;
    &:hover {
      color: var(--link-hover-color);
      border-bottom-color: var(--link-border-hover);
      background-color: var(--link-bg-hover);
      transform: translateY(-1px);
    }
    &:focus-visible {
      outline: 2px solid oklch(from var(--link-active-color) l c h / 0.5);
      outline-offset: 2px;
      border-radius: 0.375rem;
    }
  }
  .nav-link-active {
    color: var(--link-active-color);
    border-bottom-color: var(--link-active-color);
    background-color: oklch(from var(--link-active-color) l c h / 0.08);
    font-weight: 600;
    &:hover {
      background-color: oklch(from var(--link-active-color) l c h / 0.12);
    }
  }
  .nav-dropdown {
    position: relative;
  }
  .nav-dropdown-button {
    --dropdown-arrow-color: oklch(from var(--link-color) calc(l + 0.1) calc(c * 0.8) h);
    --dropdown-arrow-hover: oklch(from var(--link-hover-color) calc(l + 0.05) calc(c * 0.9) h);
    color: var(--link-color);
    background: none;
    border: none;
    padding: 0.5rem 0.75rem;
    border-bottom: 2px solid transparent;
    border-radius: 0.375rem 0.375rem 0 0;
    transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    cursor: pointer;
    font-weight: 500;
    font-size: 1rem;
    &::after {
      content: '';
      width: 0;
      height: 0;
      border-left: 4px solid transparent;
      border-right: 4px solid transparent;
      border-top: 4px solid var(--dropdown-arrow-color);
      transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
    }
    &:hover {
      color: var(--link-hover-color);
      border-bottom-color: var(--link-border-hover);
      background-color: var(--link-bg-hover);
      transform: translateY(-1px);
      &::after {
        border-top-color: var(--dropdown-arrow-hover);
        transform: rotate(180deg);
      }
    }
    &[aria-expanded="true"] {
      color: var(--link-active-color);
      border-bottom-color: var(--link-active-color);
      background-color: oklch(from var(--link-active-color) l c h / 0.08);
      &::after {
        border-top-color: var(--link-active-color);
        transform: rotate(180deg);
      }
    }
  }
  .nav-dropdown-content {
    --dropdown-bg: var(--color-background-elevated);
    --dropdown-border: oklch(from var(--nav-border) calc(l - 0.05) calc(c * 1.1) h);
    --dropdown-shadow: 0 8px 25px oklch(from var(--dropdown-bg) calc(l - 0.4) c h / 0.15);
    --dropdown-backdrop: oklch(from var(--dropdown-bg) l c h / 0.98);
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 12rem;
    background-color: var(--dropdown-backdrop);
    border: 1px solid var(--dropdown-border);
    border-radius: 0.5rem;
    box-shadow: var(--dropdown-shadow);
    padding: 0.5rem;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: all 250ms cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 50;
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    .nav-dropdown:hover &, .nav-dropdown:focus-within & {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
    }
  }
  .nav-dropdown-item {
    --item-color: var(--color-text-secondary);
    --item-hover-bg: oklch(from var(--dropdown-bg) calc(l - 0.03) calc(c + 0.05) h);
    --item-hover-color: oklch(from var(--color-brand-primary) calc(l - 0.05) calc(c * 1.05) h);
    display: block;
    color: var(--item-color);
    text-decoration: none;
    padding: 0.75rem 1rem;
    border-radius: 0.375rem;
    transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
    font-weight: 500;
    &:hover {
      background-color: var(--item-hover-bg);
      color: var(--item-hover-color);
      transform: translateX(2px);
    }
    &:focus-visible {
      outline: 2px solid oklch(from var(--color-brand-primary) l c h / 0.5);
      outline-offset: 1px;
    }
  }
  .nav-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  .nav-theme-toggle {
    --toggle-bg: transparent;
    --toggle-border: oklch(from var(--nav-border) calc(l - 0.05) calc(c * 1.1) h);
    --toggle-color: var(--color-text-tertiary);
    --toggle-hover-bg: oklch(from var(--nav-bg) calc(l - 0.02) calc(c + 0.03) h);
    --toggle-hover-border: oklch(from var(--toggle-border) calc(l - 0.1) calc(c * 1.2) h);
    --toggle-hover-color: oklch(from var(--toggle-color) calc(l - 0.15) calc(c * 1.2) h);
    background: var(--toggle-bg);
    border: 1px solid var(--toggle-border);
    border-radius: 0.375rem;
    padding: 0.5rem;
    color: var(--toggle-color);
    cursor: pointer;
    transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    &:hover {
      background-color: var(--toggle-hover-bg);
      border-color: var(--toggle-hover-border);
      color: var(--toggle-hover-color);
      transform: translateY(-1px);
      box-shadow: 0 2px 4px oklch(from var(--toggle-bg) calc(l - 0.2) c h / 0.1);
    }
    &:focus-visible {
      outline: 2px solid oklch(from var(--color-brand-primary) l c h / 0.5);
      outline-offset: 2px;
    }
  }
  .nav-mobile-toggle {
    --mobile-toggle-color: var(--color-text-secondary);
    --mobile-toggle-hover-bg: oklch(from var(--nav-bg) calc(l - 0.03) calc(c + 0.05) h);
    --mobile-toggle-hover-color: oklch(from var(--mobile-toggle-color) calc(l - 0.15) calc(c * 1.2) h);
    display: block;
    background: none;
    border: none;
    padding: 0.5rem;
    color: var(--mobile-toggle-color);
    cursor: pointer;
    border-radius: 0.5rem;
    transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
    @media (min-width: 48rem) {
      display: none;
    }
    &:hover {
      background-color: var(--mobile-toggle-hover-bg);
      color: var(--mobile-toggle-hover-color);
    }
    &:focus-visible {
      outline: 2px solid oklch(from var(--color-brand-primary) l c h / 0.5);
      outline-offset: 2px;
    }
  }
  .nav-mobile {
    --mobile-bg: var(--nav-backdrop);
    --mobile-border: var(--nav-border);
    --mobile-shadow: 0 4px 12px oklch(from var(--mobile-bg) calc(l - 0.3) c h / 0.2);
    display: block;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: var(--mobile-bg);
    border-bottom: 1px solid var(--mobile-border);
    border-top: 1px solid var(--mobile-border);
    box-shadow: var(--mobile-shadow);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: all 250ms cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 40;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    @media (min-width: 48rem) {
      display: none;
    }
    &.nav-mobile-open {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
    }
  }
  .nav-mobile-content {
    padding: 0.5rem 1rem 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }
  .nav-mobile-link {
    --mobile-link-color: var(--color-text-secondary);
    --mobile-link-hover-bg: oklch(from var(--mobile-bg) calc(l - 0.03) calc(c + 0.05) h);
    --mobile-link-hover-color: oklch(from var(--color-brand-primary) calc(l - 0.05) calc(c * 1.05) h);
    display: block;
    color: var(--mobile-link-color);
    text-decoration: none;
    padding: 0.75rem;
    border-radius: 0.375rem;
    transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
    font-weight: 500;
    &:hover {
      background-color: var(--mobile-link-hover-bg);
      color: var(--mobile-link-hover-color);
      transform: translateX(4px);
    }
    &:focus-visible {
      outline: 2px solid oklch(from var(--color-brand-primary) l c h / 0.5);
      outline-offset: 1px;
    }
  }
  .nav-mobile-link-active {
    --active-bg: var(--color-brand-primary);
    --active-text: oklch(from var(--active-bg) calc(l > 0.5 ? 0.15 : 0.85) c h);
    --active-border: oklch(from var(--active-bg) calc(l - 0.1) calc(c * 1.1) h);
    background-color: var(--active-bg);
    color: var(--active-text);
    border-left: 4px solid var(--active-border);
    padding-left: 0.5rem;
    font-weight: 600;
    &:hover {
      background-color: oklch(from var(--active-bg) calc(l - 0.05) calc(c * 1.05) h);
      color: var(--active-text);
      transform: translateX(2px);
    }
  }
  .nav-breadcrumb {
    --breadcrumb-color: var(--color-text-tertiary);
    --breadcrumb-link-color: oklch(from var(--color-brand-primary) calc(l + 0.05) calc(c * 0.9) h);
    --breadcrumb-link-hover: oklch(from var(--breadcrumb-link-color) calc(l - 0.1) calc(c * 1.1) h);
    --breadcrumb-separator: oklch(from var(--breadcrumb-color) calc(l + 0.1) calc(c * 0.6) h);
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    color: var(--breadcrumb-color);
    margin-bottom: 2rem;
    padding: 0.5rem 0;
  }
  .nav-breadcrumb-item {
    color: var(--breadcrumb-link-color);
    text-decoration: none;
    transition: color 150ms cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: 0.25rem;
    padding: 0.25rem 0.5rem;
    &:hover {
      color: var(--breadcrumb-link-hover);
      background-color: oklch(from var(--breadcrumb-link-color) l c h / 0.05);
    }
    &:focus-visible {
      outline: 2px solid oklch(from var(--breadcrumb-link-color) l c h / 0.5);
      outline-offset: 1px;
    }
    &:not(:last-child)::after {
      content: '/';
      margin-left: 0.5rem;
      color: var(--breadcrumb-separator);
      font-weight: 400;
    }
  }
  .nav-breadcrumb-current {
    color: oklch(from var(--breadcrumb-color) calc(l - 0.15) calc(c * 1.2) h);
    font-weight: 500;
    background-color: oklch(from var(--breadcrumb-color) l c h / 0.05);
    padding: 0.25rem 0.5rem;
    border-radius: 0.25rem;
  }
  .nav-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 2rem;
    gap: 0.5rem;
  }
  .nav-pagination-link {
    --pagination-bg: var(--color-background-primary);
    --pagination-border: var(--color-border-default);
    --pagination-color: var(--color-text-secondary);
    --pagination-hover-bg: oklch(from var(--pagination-bg) calc(l - 0.02) calc(c + 0.03) h);
    --pagination-hover-border: oklch(from var(--pagination-border) calc(l - 0.1) calc(c * 1.2) h);
    --pagination-hover-color: oklch(from var(--pagination-color) calc(l - 0.15) calc(c * 1.2) h);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem;
    text-decoration: none;
    background-color: var(--pagination-bg);
    border: 1px solid var(--pagination-border);
    border-radius: 0.375rem;
    transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
    min-width: 2.5rem;
    text-align: center;
    font-weight: 500;
    color: var(--pagination-color);
    &:hover {
      background-color: var(--pagination-hover-bg);
      border-color: var(--pagination-hover-border);
      color: var(--pagination-hover-color);
      transform: translateY(-1px);
      box-shadow: 0 2px 4px oklch(from var(--pagination-bg) calc(l - 0.2) c h / 0.1);
    }
    &:focus-visible {
      outline: 2px solid oklch(from var(--color-brand-primary) l c h / 0.5);
      outline-offset: 2px;
    }
  }
  .nav-pagination-link-active {
    --active-bg: var(--color-brand-primary);
    --active-text: oklch(from var(--active-bg) calc(l > 0.5 ? 0.15 : 0.85) c h);
    --active-border: oklch(from var(--active-bg) calc(l - 0.05) calc(c * 1.1) h);
    background-color: var(--active-bg);
    border-color: var(--active-border);
    color: var(--active-text);
    font-weight: 600;
    &:hover {
      background-color: oklch(from var(--active-bg) calc(l - 0.05) calc(c * 1.05) h);
      border-color: oklch(from var(--active-border) calc(l - 0.05) calc(c * 1.1) h);
      color: var(--active-text);
    }
  }
  .nav-pagination-link-disabled {
    --disabled-bg: oklch(from var(--pagination-bg) calc(l + 0.05) calc(c * 0.3) h);
    --disabled-color: oklch(from var(--pagination-color) calc(l + 0.2) calc(c * 0.4) h);
    --disabled-border: oklch(from var(--pagination-border) calc(l + 0.1) calc(c * 0.5) h);
    background-color: var(--disabled-bg);
    color: var(--disabled-color);
    border-color: var(--disabled-border);
    cursor: not-allowed;
    pointer-events: none;
    opacity: 0.6;
    &:hover {
      background-color: var(--disabled-bg);
      border-color: var(--disabled-border);
      color: var(--disabled-color);
      transform: none;
      box-shadow: none;
    }
  }
  .dark .nav-container {
    --nav-bg: var(--color-background-dark);
    --nav-border: var(--color-border-dark);
    --nav-backdrop: oklch(from var(--nav-bg) l c h / 0.95);
    box-shadow: 0 2px 8px oklch(from var(--nav-bg) calc(l - 0.1) c h / 0.3);
    &.nav-scrolled {
      box-shadow: 0 4px 16px oklch(from var(--nav-bg) calc(l - 0.15) c h / 0.4);
    }
  }
  .dark .nav-logo {
    --logo-color: var(--color-text-dark);
  }
  .dark .nav-link {
    --link-color: var(--color-text-secondary-dark);
  }
  .dark .nav-dropdown-content {
    --dropdown-bg: var(--color-background-elevated-dark);
    --dropdown-border: oklch(from var(--nav-border) calc(l + 0.1) calc(c * 1.1) h);
  }
  .nav-skip {
    position: absolute;
    top: -theme(spacing[20]);
    left: 1rem;
    background-color: var(--color-brand-primary);
    color: oklch(from var(--color-brand-primary) calc(l > 0.5 ? 0.15 : 0.85) c h);
    padding: 0.5rem 1rem;
    border-radius: 0.375rem;
    text-decoration: none;
    z-index: 100;
    transition: top 150ms ease-out;
    font-weight: 500;
    &:focus {
      top: 1rem;
    }
  }
  @media (prefers-contrast: high) {
    .nav-container {
      border-bottom-width: 3px;
    }
    .nav-link, .nav-mobile-link {
      border-bottom-width: 3px;
    }
    .nav-dropdown-content {
      border-width: 2px;
    }
    .nav-pagination-link {
      border-width: 2px;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .nav-container, .nav-link, .nav-mobile-link, .nav-pagination-link, .nav-theme-toggle, .nav-dropdown-content, .nav-mobile {
      transition: none;
    }
    .nav-dropdown-content, .nav-mobile, .nav-link:hover, .nav-mobile-link:hover {
      transform: none;
    }
  }
  @media (max-width: 40rem) {
    .nav-brand {
      flex-direction: column;
      align-items: flex-start;
      gap: 0.25rem;
    }
    .nav-logo {
      font-size: 1.125rem;
    }
    .nav-breadcrumb {
      flex-wrap: wrap;
      gap: 0.25rem;
    }
    .nav-pagination {
      flex-wrap: wrap;
      justify-content: center;
      gap: 0.25rem;
    }
  }
  .nav-brand-color {
    --nav-brand-override: var(--color-override);
  }
  .nav-link-color {
    --link-color: var(--color-override);
  }
  .nav-transparent {
    --nav-backdrop: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: none;
  }
  .nav-solid {
    --nav-backdrop: var(--nav-bg);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .nav-blur-heavy {
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
  }
  .nav-dropdown[data-dropdown-open] .nav-dropdown-content {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  .nav-mobile[data-mobile-open] {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }
  .nav-link[aria-current="page"] {
    color: var(--link-active-color);
    border-bottom-color: var(--link-active-color);
    background-color: oklch(from var(--link-active-color) l c h / 0.08);
    font-weight: 600;
  }
  .nav-mobile-link[aria-current="page"] {
    background-color: var(--color-brand-primary);
    color: oklch(from var(--color-brand-primary) calc(l > 0.5 ? 0.15 : 0.85) c h);
    border-left: 4px solid oklch(from var(--color-brand-primary) calc(l - 0.1) calc(c * 1.1) h);
    padding-left: 0.5rem;
    font-weight: 600;
  }
}
@layer components {
  .footer-base {
    background-color: var(--token-neutral-900);
    color: var(--token-neutral-300);
    border-top: 1px solid var(--token-neutral-800);
    margin-top: auto;
    .dark & {
      background-color: var(--token-pure-black);
      border-top-color: var(--token-neutral-800);
    }
  }
  .footer-container {
    max-width: 80rem;
    margin: 0 auto;
    padding: 3rem 1rem 2rem;
    @media (min-width: 40rem) {
      padding: 4rem 1.5rem 2rem;
    }
    @media (min-width: 64rem) {
      padding: 4rem 2rem 2rem;
    }
  }
  .footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
    @media (min-width: 40rem) {
      grid-template-columns: repeat(2, 1fr);
      gap: 2rem;
    }
    @media (min-width: 48rem) {
      grid-template-columns: repeat(3, 1fr);
      gap: 2rem;
    }
    @media (min-width: 64rem) {
      grid-template-columns: repeat(4, 1fr);
      gap: 3rem;
    }
  }
  .footer-grid-simple {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    @media (min-width: 48rem) {
      grid-template-columns: repeat(2, 1fr);
      gap: 2rem;
    }
    @media (min-width: 64rem) {
      grid-template-columns: 2fr 1fr;
      gap: 3rem;
    }
  }
  .footer-single-column {
    text-align: center;
    max-width: 42rem;
    margin: 0 auto;
  }
  .footer-section {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .footer-section-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--token-pure-white);
    margin-bottom: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.025em;
  }
  .footer-section-description {
    font-size: 0.875rem;
    line-height: 1.5rem;
    color: var(--token-neutral-400);
    margin-bottom: 1rem;
  }
  .footer-nav {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }
  .footer-nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
  .footer-nav-item {
    list-style: none;
  }
  .footer-nav-link {
    font-size: 0.875rem;
    color: var(--token-neutral-400);
    text-decoration: none;
    transition: color 200ms;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    &:hover {
      color: var(--token-pure-white);
    }
    &:focus {
      outline: 2px solid transparent;
      outline-offset: 2px;
      color: var(--token-pure-white);
      text-decoration: underline;
    }
  }
  .footer-nav-horizontal {
    .footer-nav-list {
      flex-direction: row;
      flex-wrap: wrap;
      gap: 1.5rem;
      justify-content: center;
    }
    @media (min-width: 40rem) {
      .footer-nav-list {
        gap: 2rem;
      }
    }
  }
  .footer-brand {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: flex-start;
    .footer-single-column & {
      align-items: center;
      text-align: center;
    }
  }
  .footer-logo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
  }
  .footer-logo-image {
    width: 2rem;
    height: 2rem;
  }
  .footer-logo-text {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--token-pure-white);
  }
  .footer-brand-description {
    font-size: 0.875rem;
    line-height: 1.5rem;
    color: var(--token-neutral-400);
    max-width: 24rem;
  }
  .footer-social {
    display: flex;
    gap: 1rem;
    align-items: center;
  }
  .footer-social-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    background-color: var(--token-neutral-800);
    color: var(--token-neutral-400);
    border-radius: 9999px;
    text-decoration: none;
    transition: all 200ms;
    border: 1px solid var(--token-neutral-700);
    &:hover {
      background-color: var(--token-neutral-700);
      color: var(--token-pure-white);
      border-color: var(--token-neutral-600);
      transform: translateY(-1px);
    }
    &:focus {
      outline: 2px solid transparent;
      outline-offset: 2px;
      box-shadow: 0 0 0 2px var(--color-info);
    }
    .dark & {
      background-color: var(--token-neutral-900);
      border-color: var(--token-neutral-800);
      &:hover {
        background-color: var(--token-neutral-800);
        border-color: var(--token-neutral-700);
      }
    }
  }
  .footer-social-icon {
    width: 1.25rem;
    height: 1.25rem;
  }
  .footer-social-twitter:hover {
    background-color: #1da1f2;
    border-color: #1da1f2;
  }
  .footer-social-facebook:hover {
    background-color: #4267b2;
    border-color: #4267b2;
  }
  .footer-social-instagram:hover {
    background-color: #e4405f;
    border-color: #e4405f;
  }
  .footer-social-linkedin:hover {
    background-color: #0077b5;
    border-color: #0077b5;
  }
  .footer-social-github:hover {
    background-color: #333;
    border-color: #333;
  }
  .footer-social-youtube:hover {
    background-color: #ff0000;
    border-color: #ff0000;
  }
  .footer-newsletter {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .footer-newsletter-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--token-pure-white);
  }
  .footer-newsletter-description {
    font-size: 0.875rem;
    color: var(--token-neutral-400);
  }
  .footer-newsletter-form {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    @media (min-width: 40rem) {
      flex-direction: row;
    }
  }
  .footer-newsletter-input {
    flex: 1;
    padding: 0.75rem;
    background-color: var(--token-neutral-800);
    border: 1px solid var(--token-neutral-700);
    border-radius: 0.375rem;
    color: var(--token-pure-white);
    font-size: 0.875rem;
    transition: all 200ms;
    &::placeholder {
      color: var(--token-neutral-500);
    }
    &:focus {
      outline: 2px solid transparent;
      outline-offset: 2px;
      border-color: var(--color-info);
      box-shadow: 0 0 0 2px var(--color-info);
      background-color: var(--token-neutral-700);
    }
    .dark & {
      background-color: var(--token-neutral-900);
      border-color: var(--token-neutral-800);
      &:focus {
        background-color: var(--token-neutral-800);
      }
    }
  }
  .footer-newsletter-button {
    padding: 0.75rem 1.5rem;
    background-color: var(--color-brand-primary);
    color: var(--token-pure-white);
    border: none;
    border-radius: 0.375rem;
    font-size: 0.875rem;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 200ms;
    white-space: nowrap;
    &:hover {
      background-color: oklch( from var(--color-brand-primary) calc(l - 0.10) c h );
    }
    &:focus {
      outline: 2px solid transparent;
      outline-offset: 2px;
      box-shadow: 0 0 0 2px oklch( from var(--color-brand-primary) l c h / 0.5 );
    }
    &:disabled {
      background-color: var(--token-neutral-600);
      cursor: not-allowed;
    }
  }
  .footer-bottom {
    border-top: 1px solid var(--token-neutral-800);
    margin-top: 2rem;
    padding-top: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
    text-align: center;
    @media (min-width: 40rem) {
      flex-direction: row;
      justify-content: space-between;
      text-align: left;
    }
  }
  .footer-copyright {
    font-size: 0.875rem;
    color: var(--token-neutral-500);
  }
  .footer-bottom-links {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    justify-content: center;
    @media (min-width: 40rem) {
      justify-content: flex-end;
    }
  }
  .footer-bottom-link {
    font-size: 0.875rem;
    color: var(--token-neutral-500);
    text-decoration: none;
    transition: color 200ms;
    &:hover {
      color: var(--token-neutral-300);
      text-decoration: underline;
    }
    &:focus {
      outline: 2px solid transparent;
      outline-offset: 2px;
      color: var(--token-pure-white);
      text-decoration: underline;
    }
  }
  .footer-contact {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }
  .footer-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    font-size: 0.875rem;
    color: var(--token-neutral-400);
  }
  .footer-contact-icon {
    width: 1.25rem;
    height: 1.25rem;
    color: var(--token-neutral-500);
    flex-shrink: 0;
    margin-top: 0.25rem;
  }
  .footer-contact-link {
    color: var(--token-neutral-400);
    text-decoration: none;
    transition: color 200ms;
    &:hover {
      color: var(--token-pure-white);
      text-decoration: underline;
    }
  }
  .footer-minimal {
    padding: 1.5rem 0;
    text-align: center;
    border-top: 1px solid var(--token-neutral-200);
    background-color: var(--token-neutral-50);
    color: var(--token-neutral-600);
    .dark & {
      background-color: var(--token-neutral-900);
      border-top-color: var(--token-neutral-800);
      color: var(--token-neutral-400);
    }
  }
  .footer-dark {
    background-color: var(--token-pure-black);
    border-top-color: var(--token-neutral-900);
  }
  .footer-light {
    background-color: var(--token-pure-white);
    color: var(--token-neutral-700);
    border-top: 1px solid var(--token-neutral-200);
    .footer-section-title {
      color: var(--token-neutral-900);
    }
    .footer-nav-link {
      color: var(--token-neutral-600);
      &:hover {
        color: var(--token-neutral-900);
      }
    }
    .footer-logo-text {
      color: var(--token-neutral-900);
    }
    .footer-brand-description, .footer-section-description {
      color: var(--token-neutral-600);
    }
    .footer-social-link {
      background-color: var(--token-neutral-100);
      color: var(--token-neutral-600);
      border-color: var(--token-neutral-200);
      &:hover {
        background-color: var(--token-neutral-200);
        color: var(--token-neutral-900);
      }
    }
    .footer-newsletter-input {
      background-color: var(--token-neutral-100);
      border-color: var(--token-neutral-300);
      color: var(--token-neutral-900);
      &::placeholder {
        color: var(--token-neutral-500);
      }
      &:focus {
        background-color: var(--token-pure-white);
      }
    }
    .footer-bottom {
      border-top-color: var(--token-neutral-200);
    }
    .footer-copyright {
      color: var(--token-neutral-500);
    }
    .footer-bottom-link {
      color: var(--token-neutral-500);
      &:hover {
        color: var(--token-neutral-700);
      }
    }
  }
  @media (max-width: 40rem) {
    .footer-container {
      padding: 2rem 1rem 1.5rem;
    }
    .footer-grid {
      gap: 1.5rem;
    }
    .footer-social {
      gap: 0.75rem;
    }
    .footer-social-link {
      width: 2rem;
      height: 2rem;
    }
    .footer-social-icon {
      width: 1rem;
      height: 1rem;
    }
    .footer-newsletter-form {
      gap: 0.5rem;
    }
    .footer-bottom {
      margin-top: 1.5rem;
      padding-top: 1rem;
    }
  }
  @media print {
    .footer-base {
      background-color: white !important;
      color: black !important;
      border-top: 2px solid black !important;
      break-before: page;
    }
    .footer-social, .footer-newsletter {
      display: none;
    }
    .footer-nav-link {
      color: black !important;
    }
    .footer-logo-text, .footer-section-title {
      color: black !important;
    }
    .footer-copyright, .footer-bottom-link {
      color: #666 !important;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .footer-social-link, .footer-nav-link, .footer-newsletter-input, .footer-newsletter-button {
      transition: none;
    }
    .footer-social-link:hover {
      transform: none;
    }
  }
  @media (prefers-contrast: high) {
    .footer-base {
      border-top-width: 2px;
    }
    .footer-nav-link {
      font-weight: 500;
    }
    .footer-social-link {
      border-width: 2px;
    }
    .footer-newsletter-input {
      border-width: 2px;
    }
  }
}
@layer components {
  .layout-site-wrapper {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
  }
  .layout-site-header {
    flex-shrink: 0;
    z-index: var(--z-sticky, 1020);
  }
  .layout-site-main {
    flex: 1;
    padding: var(--spacing-component-xl, 2rem) 0;
    @media (min-width: 64rem) {
      padding: 3rem 0;
    }
  }
  .layout-site-footer {
    flex-shrink: 0;
    margin-top: auto;
  }
  .layout-container-default {
    max-width: var(--content-width-default, 56rem);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--spacing-component-md, 1rem);
    padding-right: var(--spacing-component-md, 1rem);
    @media (min-width: 64rem) {
      padding-left: var(--spacing-component-xl, 2rem);
      padding-right: var(--spacing-component-xl, 2rem);
    }
  }
  .layout-container-wide {
    max-width: var(--content-width-wide, 72rem);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--spacing-component-md, 1rem);
    padding-right: var(--spacing-component-md, 1rem);
    @media (min-width: 64rem) {
      padding-left: var(--spacing-component-xl, 2rem);
      padding-right: var(--spacing-component-xl, 2rem);
    }
  }
  .layout-container-narrow {
    max-width: var(--content-width-narrow, 42rem);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--spacing-component-md, 1rem);
    padding-right: var(--spacing-component-md, 1rem);
  }
  .layout-container-full {
    max-width: var(--content-width-full, 80rem);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--spacing-component-md, 1rem);
    padding-right: var(--spacing-component-md, 1rem);
    @media (min-width: 64rem) {
      padding-left: var(--spacing-component-xl, 2rem);
      padding-right: var(--spacing-component-xl, 2rem);
    }
  }
  .layout-container-prose {
    max-width: 65ch;
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--spacing-component-md, 1rem);
    padding-right: var(--spacing-component-md, 1rem);
    @media (min-width: 64rem) {
      padding-left: var(--spacing-component-xl, 2rem);
      padding-right: var(--spacing-component-xl, 2rem);
    }
  }
  .layout-grid-2 {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-component-xl, 2rem);
    @media (min-width: 64rem) {
      grid-template-columns: 2fr 1fr;
      gap: 3rem;
    }
    &.layout-grid-2-reverse {
      @media (min-width: 64rem) {
        grid-template-columns: 1fr 2fr;
      }
    }
    &.layout-grid-2-equal {
      @media (min-width: 64rem) {
        grid-template-columns: 1fr 1fr;
      }
    }
  }
  .layout-grid-3 {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-component-lg, 1.5rem);
    @media (min-width: 48rem) {
      grid-template-columns: repeat(2, 1fr);
    }
    @media (min-width: 64rem) {
      grid-template-columns: repeat(3, 1fr);
    }
    &.layout-grid-3-equal-mobile {
      @media (min-width: 40rem) {
        grid-template-columns: repeat(2, 1fr);
      }
      @media (min-width: 64rem) {
        grid-template-columns: repeat(3, 1fr);
      }
    }
  }
  .layout-grid-4 {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-component-lg, 1.5rem);
    @media (min-width: 40rem) {
      grid-template-columns: repeat(2, 1fr);
    }
    @media (min-width: 64rem) {
      grid-template-columns: repeat(4, 1fr);
    }
  }
  .layout-blog-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5rem;
    @media (max-width: 40rem) {
      grid-template-columns: 1fr;
    }
  }
  .layout-blog-grid-compact {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
    @media (max-width: 40rem) {
      grid-template-columns: 1fr;
    }
  }
  .layout-sidebar-left {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-component-xl, 2rem);
    @media (min-width: 64rem) {
      grid-template-columns: 250px 1fr;
      gap: 3rem;
    }
    &.layout-sidebar-left-wide {
      @media (min-width: 64rem) {
        grid-template-columns: 300px 1fr;
      }
    }
  }
  .layout-sidebar-right {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-component-xl, 2rem);
    @media (min-width: 64rem) {
      grid-template-columns: 1fr 250px;
      gap: 3rem;
    }
    &.layout-sidebar-right-wide {
      @media (min-width: 64rem) {
        grid-template-columns: 1fr 300px;
      }
    }
  }
  .layout-sidebar-aside {
    @media (max-width: 64rem) {
      order: 2;
    }
  }
  .layout-sidebar-main {
    min-width: 0;
    @media (max-width: 64rem) {
      order: 1;
    }
  }
  .layout-hero-default {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    padding: var(--spacing-component-xl, 2rem) 0;
    background: var(--color-background-secondary);
    @media (min-width: 64rem) {
      min-height: 70vh;
      padding: 4rem 0;
    }
  }
  .layout-hero-fullscreen {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: var(--spacing-component-xl, 2rem) 0;
    background: var(--color-background-secondary);
    @media (min-width: 64rem) {
      padding: 4rem 0;
    }
  }
  .layout-hero-compact {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 40vh;
    padding: var(--spacing-component-lg, 1.5rem) 0;
    background: var(--color-background-secondary);
  }
  .layout-hero-content {
    text-align: center;
    max-width: 56rem;
    margin: 0 auto;
    padding: 0 var(--spacing-component-md, 1rem);
  }
  .layout-grid-card {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-component-lg, 1.5rem);
    @media (min-width: 40rem) {
      grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    }
    &.layout-grid-card-sm {
      @media (min-width: 40rem) {
        grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
      }
    }
    &.layout-grid-card-lg {
      @media (min-width: 40rem) {
        grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
      }
    }
  }
  .layout-grid-masonry {
    columns: 1;
    column-gap: var(--spacing-component-lg, 1.5rem);
    @media (min-width: 40rem) {
      columns: 2;
    }
    @media (min-width: 64rem) {
      columns: 3;
    }
    @media (min-width: 80rem) {
      columns: 4;
    }
    > * {
      break-inside: avoid;
      margin-bottom: var(--spacing-component-lg, 1.5rem);
    }
  }
  .layout-flex-space-between {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-component-md, 1rem);
    @media (max-width: 40rem) {
      flex-direction: column;
      align-items: stretch;
    }
  }
  .layout-flex-center {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-component-md, 1rem);
  }
  .layout-flex-start {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: var(--spacing-component-md, 1rem);
  }
  .layout-flex-end {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: var(--spacing-component-md, 1rem);
  }
  .layout-flex-space-around {
    display: flex;
    justify-content: space-around;
    align-items: center;
    gap: var(--spacing-component-md, 1rem);
  }
  .layout-flex-space-evenly {
    display: flex;
    justify-content: space-evenly;
    align-items: center;
    gap: var(--spacing-component-md, 1rem);
  }
  .layout-stack-tight {
    display: flex;
    flex-direction: column;
    & > * + * {
      margin-top: 0.5rem;
    }
  }
  .layout-stack-normal {
    display: flex;
    flex-direction: column;
    & > * + * {
      margin-top: 1rem;
    }
  }
  .layout-stack-loose {
    display: flex;
    flex-direction: column;
    & > * + * {
      margin-top: 2rem;
    }
  }
  .layout-stack-extra-loose {
    display: flex;
    flex-direction: column;
    & > * + * {
      margin-top: 3rem;
    }
  }
  .layout-inline-tight {
    display: flex;
    align-items: center;
    & > * + * {
      margin-left: 0.5rem;
    }
  }
  .layout-inline-normal {
    display: flex;
    align-items: center;
    & > * + * {
      margin-left: 1rem;
    }
  }
  .layout-inline-loose {
    display: flex;
    align-items: center;
    & > * + * {
      margin-left: 1.5rem;
    }
  }
  .layout-section-default {
    padding: var(--spacing-component-xl, 2rem) 0;
    @media (min-width: 64rem) {
      padding: 4rem 0;
    }
  }
  .layout-section-sm {
    padding: var(--spacing-component-lg, 1.5rem) 0;
    @media (min-width: 64rem) {
      padding: 3rem 0;
    }
  }
  .layout-section-lg {
    padding: 3rem 0;
    @media (min-width: 64rem) {
      padding: 5rem 0;
    }
  }
  .layout-sticky-top {
    position: sticky;
    top: 0;
    z-index: var(--z-sticky, 1020);
  }
  .layout-sticky-sidebar {
    position: sticky;
    top: var(--spacing-component-xl, 2rem);
    @media (max-width: 64rem) {
      position: static;
    }
  }
  .layout-mobile-only {
    @media (min-width: 48rem) {
      display: none;
    }
  }
  .layout-tablet-up {
    @media (max-width: 48rem) {
      display: none;
    }
  }
  .layout-desktop-only {
    @media (max-width: 64rem) {
      display: none;
    }
  }
  .layout-nav-header {
    position: sticky;
    top: 0;
    z-index: 40;
    background-color: color( from var(--color-background-primary) srgb r g b / 0.95 );
    backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--color-border-default);
  }
  .layout-nav-items {
    display: none;
    @media (min-width: 48rem) {
      display: flex;
      & > * + * {
        margin-left: 2rem;
      }
    }
  }
  .layout-nav-mobile {
    display: block;
    @media (min-width: 48rem) {
      display: none;
    }
  }
  .layout-blog-header {
    max-width: 72rem;
    margin-left: auto;
    margin-right: auto;
    padding: 2rem 1rem;
    @media (min-width: 40rem) {
      padding: 3rem 1.5rem;
    }
  }
  .layout-article-content {
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
    padding: 2rem 1rem;
  }
  .layout-article-header {
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
    & > * + * {
      margin-top: 1rem;
    }
    padding: 2rem 1rem;
  }
  .layout-article-body {
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
    max-width: none;
  }
  .layout-article-footer {
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
    padding: 2rem 1rem;
    border-top: 1px solid var(--color-border-default);
  }
  .layout-section-divider {
    border-top: 1px solid var(--color-border-default);
    margin: 2rem 0;
  }
  .layout-content-divider {
    border-top: 1px solid var(--color-border-default);
    margin: 1rem 0;
  }
  .layout-responsive-padding {
    padding-left: 1rem;
    padding-right: 1rem;
    @media (min-width: 40rem) {
      padding-left: 1.5rem;
      padding-right: 1.5rem;
    }
    @media (min-width: 64rem) {
      padding-left: 2rem;
      padding-right: 2rem;
    }
  }
  .layout-responsive-margin {
    margin-left: 1rem;
    margin-right: 1rem;
    @media (min-width: 40rem) {
      margin-left: 1.5rem;
      margin-right: 1.5rem;
    }
    @media (min-width: 64rem) {
      margin-left: 2rem;
      margin-right: 2rem;
    }
  }
  .layout-constrain-narrow {
    max-width: 32rem;
    margin-left: auto;
    margin-right: auto;
  }
  .layout-constrain-normal {
    max-width: 56rem;
    margin-left: auto;
    margin-right: auto;
  }
  .layout-constrain-wide {
    max-width: 72rem;
    margin-left: auto;
    margin-right: auto;
  }
  .layout-constrain-full {
    max-width: 80rem;
    margin-left: auto;
    margin-right: auto;
  }
  .layout-aspect-video {
    aspect-ratio: 16 / 9;
  }
  .layout-aspect-square {
    aspect-ratio: 1 / 1;
  }
  .layout-aspect-portrait {
    aspect-ratio: 3 / 4;
  }
  .layout-aspect-landscape {
    aspect-ratio: 4 / 3;
  }
  .layout-overflow-hidden {
    overflow: hidden;
  }
  .layout-overflow-scroll {
    overflow: auto;
  }
  .layout-z-dropdown {
    z-index: 10;
  }
  .layout-z-sticky {
    z-index: 20;
  }
  .layout-z-fixed {
    z-index: 30;
  }
  .layout-z-modal-backdrop {
    z-index: 40;
  }
  .layout-z-modal {
    z-index: 50;
  }
  .layout-z-popover {
    z-index: 60;
  }
  .layout-z-tooltip {
    z-index: 70;
  }
  .dark .layout-nav-header {
    background-color: color( from var(--color-background-primary) srgb r g b / 0.95 );
    border-bottom-color: var(--color-border-default);
  }
  .dark .layout-section-divider {
    border-top-color: var(--color-border-default);
  }
  .dark .layout-content-divider {
    border-top-color: var(--color-border-default);
  }
  .dark .layout-article-footer {
    border-top-color: var(--color-border-default);
  }
}
@layer components {
  .article-meta-base {
    --meta-color: var(--color-text-secondary);
    --meta-icon-color: var(--color-text-tertiary);
    --meta-link-color: var(--color-brand-primary);
    --meta-link-hover-color: oklch(from var(--meta-link-color) calc(l - 0.1) c h);
    --meta-link-hover-bg: oklch(from var(--meta-link-color) l c h / 0.08);
    --meta-subtle-color: oklch(from var(--meta-color) calc(l + 0.15) c h);
    --meta-muted-color: oklch(from var(--meta-color) l c h / 0.6);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1rem;
    color: var(--meta-color);
    font-size: 0.875rem;
    line-height: 1.5;
  }
  .article-meta-size-xs {
    gap: 0.5rem;
    font-size: 0.75rem;
  }
  .article-meta-size-sm {
    gap: 0.75rem;
    font-size: 0.875rem;
  }
  .article-meta-size-md {
    gap: 1rem;
    font-size: 1rem;
  }
  .article-meta-size-lg {
    gap: 1.5rem;
    font-size: 1.125rem;
  }
  .article-meta-style-compact {
    gap: 0.5rem;
    font-size: 0.75rem;
  }
  .article-meta-style-card {
    padding: 1rem;
    background-color: oklch(from var(--meta-color) l c h / 0.05);
    border-radius: 0.5rem;
    border: 1px solid oklch(from var(--meta-color) l c h / 0.1);
  }
  .article-meta-style-inline {
    gap: 0.75rem;
    flex-wrap: nowrap;
  }
  .article-meta-item {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    color: var(--meta-color);
  }
  .article-meta-item svg, .article-meta-icon {
    width: 1rem;
    height: 1rem;
    color: var(--meta-icon-color);
    flex-shrink: 0;
  }
  .article-meta-size-xs .article-meta-icon {
    width: 0.875rem;
    height: 0.875rem;
  }
  .article-meta-size-lg .article-meta-icon {
    width: 1.25rem;
    height: 1.25rem;
  }
  .article-meta-item time {
    color: var(--meta-color);
  }
  .article-meta-item-publish time {
    font-weight: 500;
  }
  .article-meta-item-updated time {
    color: var(--meta-subtle-color);
    font-style: italic;
  }
  .article-meta-item-author {
    color: var(--meta-color);
  }
  .article-meta-link-author {
    color: var(--meta-link-color);
    text-decoration: none;
    transition: all 200ms;
    padding: 0.25rem 0.5rem;
    margin: calc(0.25rem * -1) calc(0.5rem * -1);
    border-radius: 0.25rem;
  }
  .article-meta-link-author:hover {
    color: var(--meta-link-hover-color);
    background-color: var(--meta-link-hover-bg);
  }
  .article-meta-link-author:focus-visible {
    outline: 2px solid var(--meta-link-color);
    outline-offset: 2px;
  }
  .article-meta-item-category {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
  }
  .article-meta-link-category {
    color: var(--meta-link-color);
    text-decoration: none;
    font-weight: 500;
    transition: all 200ms;
    padding: 0.25rem 0.5rem;
    margin: calc(0.25rem * -1) calc(0.5rem * -1);
    border-radius: 0.25rem;
  }
  .article-meta-link-category:hover {
    color: var(--meta-link-hover-color);
    background-color: var(--meta-link-hover-bg);
  }
  .article-meta-link-category:focus-visible {
    outline: 2px solid var(--meta-link-color);
    outline-offset: 2px;
  }
  .article-meta-item-reading-time {
    color: var(--meta-color);
    font-variant-numeric: tabular-nums;
  }
  .article-meta-separator {
    color: var(--meta-muted-color);
    user-select: none;
  }
  .article-meta-separator::before {
    content: "•";
  }
  .article-meta-separator-pipe::before {
    content: "|";
  }
  .article-meta-separator-slash::before {
    content: "/";
  }
  .article-meta-separator-dash::before {
    content: "—";
  }
  .article-meta-intent-featured {
    --meta-link-color: var(--color-brand-primary);
    --meta-link-hover-color: oklch(from var(--color-brand-primary) calc(l - 0.1) c h);
    font-weight: 600;
  }
  .article-meta-intent-archived {
    --meta-color: oklch(from var(--color-text-secondary) l c h / 0.5);
    --meta-icon-color: oklch(from var(--color-text-tertiary) l c h / 0.5);
  }
  .article-meta-intent-draft {
    --meta-color: var(--color-warning);
    --meta-icon-color: var(--color-warning);
  }
  @media (max-width: 40rem) {
    .article-meta-base {
      gap: 0.75rem;
      font-size: 0.75rem;
    }
    .article-meta-icon {
      width: 0.875rem;
      height: 0.875rem;
    }
    .article-meta-style-inline {
      flex-wrap: wrap;
    }
  }
  @media (prefers-contrast: high) {
    .article-meta-base {
      --meta-color: oklch(from var(--color-text-secondary) calc(l < 0.5 ? 0.1 : 0.9) c h);
    }
    .article-meta-link-author, .article-meta-link-category {
      text-decoration: underline;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .article-meta-link-author, .article-meta-link-category {
      transition: none;
    }
  }
  @media print {
    .article-meta-base {
      color: black;
    }
    .article-meta-link-author, .article-meta-link-category {
      color: black;
      text-decoration: none;
    }
  }
}
@layer components {
  .category-base {
    --category-color: var(--color-text-secondary);
    --category-bg: var(--color-background-secondary);
    --category-border: var(--color-border-default);
    --category-hover-color: var(--color-brand-primary);
    --category-hover-bg: oklch(from var(--color-brand-primary) l c h / 0.08);
    --category-hover-border: oklch(from var(--color-brand-primary) l c h / 0.5);
    --category-focus-ring: oklch(from var(--color-brand-primary) l c h / 0.2);
    --category-shadow: 0 1px 3px oklch(from var(--category-color) l c h / 0.1);
    --category-shadow-hover: 0 2px 8px oklch(from var(--category-hover-color) l c h / 0.15);
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--category-color);
    background-color: var(--category-bg);
    border: 1px solid var(--category-border);
    border-radius: 0.5rem;
    transition: all 200ms;
  }
  .category-size-xs {
    padding: 0.125rem 0.5rem;
    font-size: 0.75rem;
    gap: 0.25rem;
  }
  .category-size-sm {
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
    gap: 0.375rem;
  }
  .category-size-md {
    padding: 0.5rem 1rem;
    font-size: 1rem;
    gap: 0.5rem;
  }
  .category-size-lg {
    padding: 0.75rem 1.5rem;
    font-size: 1.125rem;
    gap: 0.75rem;
  }
  .category-style-outlined {
    --category-bg: transparent;
    --category-border: oklch(from var(--category-color) l c h / 0.4);
    border-width: 1.5px;
  }
  .category-style-minimal {
    --category-bg: transparent;
    --category-border: transparent;
    padding-left: 0;
    padding-right: 0;
  }
  .category-style-minimal:hover {
    --category-bg: transparent;
  }
  .category-style-solid {
    --category-bg: var(--color-brand-primary-overlay);
    --category-border: transparent;
    --category-color: var(--color-brand-primary);
    --category-hover-bg: var(--color-brand-primary-backdrop);
  }
  .category-state-clickable {
    cursor: pointer;
    text-decoration: none;
    user-select: none;
  }
  .category-state-clickable:hover {
    color: var(--category-hover-color);
    background-color: var(--category-hover-bg);
    border-color: var(--category-hover-border);
    transform: translateY(-1px);
    box-shadow: var(--category-shadow-hover);
  }
  .category-state-clickable:active {
    transform: translateY(0);
    box-shadow: none;
  }
  .category-state-clickable:focus-visible {
    outline: 2px solid var(--category-focus-ring);
    outline-offset: 2px;
  }
  .category-state-active, .category-state-clickable[aria-current="page"] {
    color: var(--category-hover-color);
    background-color: var(--category-hover-bg);
    border-color: var(--category-hover-border);
  }
  .category-layout-badge {
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: 1;
    border-radius: 9999px;
    text-transform: uppercase;
    letter-spacing: 0.025em;
    gap: 0.375rem;
  }
  .category-layout-card {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.5rem;
    border-radius: 0.75rem;
    --category-shadow: 0 4px 12px oklch(from var(--category-color) l c h / 0.08);
    --category-shadow-hover: 0 8px 24px oklch(from var(--category-hover-color) l c h / 0.12);
    box-shadow: var(--category-shadow);
  }
  .category-layout-card.category-state-clickable:hover {
    transform: translateY(-2px);
    box-shadow: var(--category-shadow-hover);
  }
  .category-card-icon {
    width: 3rem;
    height: 3rem;
    color: var(--category-hover-color);
  }
  .category-card-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--color-text-primary);
    margin: 0;
  }
  .category-state-clickable:hover .category-card-title {
    color: var(--category-hover-color);
  }
  .category-card-description {
    font-size: 0.875rem;
    color: var(--color-text-secondary);
    line-height: 1.6;
  }
  .category-card-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.875rem;
    color: var(--color-text-tertiary);
    margin-top: auto;
  }
  .category-layout-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    padding: 1rem;
    background-color: var(--color-background-secondary);
    border-radius: 0.5rem;
  }
  .category-icon {
    width: 1rem;
    height: 1rem;
    flex-shrink: 0;
  }
  .category-size-xs .category-icon {
    width: 0.75rem;
    height: 0.75rem;
  }
  .category-size-lg .category-icon {
    width: 1.5rem;
    height: 1.5rem;
  }
  .category-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 0.5rem;
    font-size: 0.75rem;
    font-weight: 700;
    background-color: oklch(from var(--category-color) l c h / 0.15);
    border-radius: 9999px;
    margin-left: 0.5rem;
  }
  .category-state-clickable:hover .category-count {
    background-color: oklch(from var(--category-hover-color) l c h / 0.2);
    color: var(--category-hover-color);
  }
  .category-intent-featured {
    --category-bg: linear-gradient(
      135deg,
      var(--color-brand-primary-overlay),
      var(--color-brand-secondary-overlay)
    );
    --category-border: var(--color-brand-primary);
    --category-color: var(--color-brand-primary);
    --category-hover-bg: linear-gradient(
      135deg,
      var(--color-brand-primary-backdrop),
      var(--color-brand-secondary-overlay)
    );
    background: var(--category-bg);
  }
  .category-intent-featured:hover {
    background: var(--category-hover-bg);
  }
  .category-intent-popular::after {
    content: "🔥";
    margin-left: 0.25rem;
    font-size: 0.875em;
  }
  .category-intent-new::after {
    content: "New";
    margin-left: 0.5rem;
    padding: 0.125rem 0.375rem;
    font-size: 0.75rem;
    font-weight: 700;
    background-color: var(--color-success);
    color: white;
    border-radius: 9999px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }
  .categories-container {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    list-style: none;
    padding: 0;
    margin: 0;
  }
  .categories-container-tight {
    gap: 0.25rem;
  }
  .categories-container-spacious {
    gap: 1rem;
  }
  .categories-container-vertical {
    flex-direction: column;
    gap: 0.5rem;
  }
  .categories-container-vertical .category-base {
    justify-content: space-between;
    width: 100%;
  }
  .categories-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1.5rem;
  }
  @media (max-width: 40rem) {
    .categories-grid {
      grid-template-columns: 1fr;
      gap: 1rem;
    }
  }
  @media (max-width: 40rem) {
    .category-base {
      padding: 0.375rem 0.75rem;
      font-size: 0.75rem;
    }
    .category-layout-card {
      padding: 1rem;
    }
    .categories-container {
      gap: 0.375rem;
    }
  }
  @media (prefers-contrast: high) {
    .category-base, .category-layout-badge, .category-layout-card {
      border-width: 2px;
      --category-border: oklch(from var(--category-color) calc(l - 0.2) calc(max(0.15, c)) h);
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .category-state-clickable {
      transition: none;
    }
    .category-state-clickable:hover, .category-layout-card.category-state-clickable:hover {
      transform: none;
    }
  }
  @media print {
    .category-base, .category-layout-badge {
      border: 1px solid currentColor;
      break-inside: avoid;
    }
    .category-layout-card {
      break-inside: avoid;
      page-break-inside: avoid;
    }
  }
}
@layer components {
  .tag-base {
    --tag-color: var(--color-text-secondary);
    --tag-bg: var(--color-background-secondary);
    --tag-border: var(--color-border-default);
    --tag-hover-color: var(--color-brand-primary);
    --tag-hover-bg: oklch(from var(--color-brand-primary) l c h / 0.08);
    --tag-hover-border: oklch(from var(--color-brand-primary) l c h / 0.3);
    --tag-focus-ring: oklch(from var(--color-brand-primary) l c h / 0.2);
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.75rem;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
    color: var(--tag-color);
    background-color: var(--tag-bg);
    border: 1px solid var(--tag-border);
    border-radius: 9999px;
    transition: all 200ms;
  }
  .tag-size-xs {
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    gap: 0.25rem;
  }
  .tag-size-sm {
    padding: 0.375rem 0.625rem;
    font-size: 0.875rem;
    gap: 0.375rem;
  }
  .tag-size-md {
    padding: 0.5rem 0.875rem;
    font-size: 1rem;
    gap: 0.5rem;
  }
  .tag-size-lg {
    padding: 0.625rem 1rem;
    font-size: 1.125rem;
    gap: 0.5rem;
  }
  .tag-style-outlined {
    --tag-bg: transparent;
    --tag-border: oklch(from var(--color-brand-primary) l c h / 0.3);
    --tag-hover-bg: oklch(from var(--color-brand-primary) l c h / 0.08);
    border-width: 1.5px;
  }
  .tag-style-solid {
    --tag-bg: var(--color-brand-primary-overlay);
    --tag-color: var(--color-brand-primary);
    --tag-border: transparent;
    --tag-hover-bg: var(--color-brand-primary-backdrop);
  }
  .tag-style-ghost {
    --tag-bg: transparent;
    --tag-border: transparent;
    --tag-hover-bg: var(--color-background-secondary);
  }
  .tag-state-clickable {
    cursor: pointer;
    user-select: none;
  }
  .tag-state-clickable:hover {
    color: var(--tag-hover-color);
    background-color: var(--tag-hover-bg);
    border-color: var(--tag-hover-border);
    transform: translateY(-1px);
  }
  .tag-state-clickable:active {
    transform: translateY(0);
  }
  .tag-state-clickable:focus-visible {
    outline: 2px solid var(--tag-focus-ring);
    outline-offset: 2px;
  }
  .tag-icon {
    width: 1rem;
    height: 1rem;
    flex-shrink: 0;
  }
  .tag-size-xs .tag-icon {
    width: 0.75rem;
    height: 0.75rem;
  }
  .tag-size-lg .tag-icon {
    width: 1.25rem;
    height: 1.25rem;
  }
  .tag-prefix-hash::before {
    content: "#";
    opacity: 0.6;
    margin-right: calc(0.25rem * -0.5);
  }
  .tag-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 0.375rem;
    font-size: 0.75rem;
    font-weight: 600;
    background-color: oklch(from var(--tag-hover-color) l c h / 0.15);
    border-radius: 9999px;
    margin-left: 0.25rem;
  }
  .tag-state-removable {
    padding-right: 0.375rem;
  }
  .tag-remove-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.25rem;
    height: 1.25rem;
    margin-left: 0.25rem;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 9999px;
    color: var(--tag-color);
    cursor: pointer;
    transition: all 200ms;
  }
  .tag-remove-button:hover {
    background-color: oklch(from var(--tag-color) l c h / 0.15);
    color: var(--color-danger);
  }
  .tag-remove-button:focus-visible {
    outline: 2px solid var(--tag-focus-ring);
    outline-offset: 1px;
  }
  .tag-remove-button svg {
    width: 0.875rem;
    height: 0.875rem;
  }
  .tag-intent-featured {
    --tag-bg: var(--color-brand-primary-overlay);
    --tag-border: var(--color-brand-primary);
    --tag-color: var(--color-brand-primary);
    --tag-hover-bg: var(--color-brand-primary-backdrop);
    font-weight: 600;
  }
  .tag-intent-new {
    --tag-bg: var(--color-success-ghost);
    --tag-border: var(--color-success);
    --tag-color: var(--color-success);
    --tag-hover-bg: oklch(from var(--color-success-ghost) calc(l - 0.05) c h);
  }
  .tag-intent-draft {
    --tag-bg: var(--color-warning-ghost);
    --tag-border: var(--color-warning);
    --tag-color: var(--color-warning);
    --tag-hover-bg: oklch(from var(--color-warning-ghost) calc(l - 0.05) c h);
  }
  .tag-intent-archived {
    --tag-bg: oklch(from var(--color-text-tertiary) l c h / 0.1);
    --tag-border: var(--color-border-subtle);
    --tag-color: var(--color-text-tertiary);
    --tag-hover-bg: oklch(from var(--color-text-tertiary) l c h / 0.15);
  }
  .tags-container {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
  }
  .tags-container-tight {
    gap: 0.25rem;
  }
  .tags-container-spacious {
    gap: 0.75rem;
  }
  .tags-label {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text-secondary);
    margin-right: 0.5rem;
  }
  .tag-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: center;
    align-items: center;
    padding: 1rem;
  }
  .tag-cloud .tag-base[data-weight="1"] {
    font-size: 0.75rem;
    opacity: 0.7;
  }
  .tag-cloud .tag-base[data-weight="2"] {
    font-size: 0.875rem;
    opacity: 0.8;
  }
  .tag-cloud .tag-base[data-weight="3"] {
    font-size: 1rem;
    opacity: 0.9;
  }
  .tag-cloud .tag-base[data-weight="4"] {
    font-size: 1.125rem;
    opacity: 1;
  }
  .tag-cloud .tag-base[data-weight="5"] {
    font-size: 1.25rem;
    opacity: 1;
    font-weight: 700;
  }
  @media (max-width: 40rem) {
    .tag-base {
      padding: 0.25rem 0.625rem;
      font-size: 0.75rem;
    }
    .tags-container {
      gap: 0.375rem;
    }
  }
  @media (prefers-contrast: high) {
    .tag-base {
      border-width: 2px;
      --tag-border: oklch(from var(--tag-color) calc(l - 0.2) calc(max(0.125, c)) h);
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .tag-base, .tag-state-clickable, .tag-remove-button {
      transition: none;
    }
    .tag-state-clickable:hover {
      transform: none;
    }
  }
  @media print {
    .tag-state-removable, .tag-remove-button {
      display: none;
    }
    .tag-base {
      border: 1px solid currentColor;
      break-inside: avoid;
    }
  }
}
@layer components {
  .admonition {
    margin-bottom: calc(var(--spacing) * 4);
    border-top-right-radius: var(--radius-lg);
    border-bottom-right-radius: var(--radius-lg);
    border-left-style: var(--tw-border-style);
    border-left-width: 4px;
    padding: calc(var(--spacing) * 4);
    --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);
  }
  .admonition-title {
    margin-bottom: calc(var(--spacing) * 2);
    display: flex;
    align-items: center;
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    margin-bottom: 0.75rem !important;
    margin-top: 0 !important;
  }
  .admonition-content {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  .admonition-content p:last-child {
    margin-bottom: 0;
  }
  .admonition-title::before {
    margin-right: calc(var(--spacing) * 2);
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .admonition.note {
    border-color: var(--color-blue-500);
    background-color: var(--color-blue-50);
    color: var(--color-blue-900);
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(28.2% 0.091 267.935) 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-blue-950) 30%, transparent);
      }
    }
    &:where(.dark, .dark *) {
      color: var(--color-blue-100);
    }
  }
  .admonition.note .admonition-title {
    color: var(--color-blue-800);
    &:where(.dark, .dark *) {
      color: var(--color-blue-200);
    }
  }
  .admonition.note .admonition-title::before {
    content: "ℹ️";
  }
  .admonition.info {
    border-color: var(--color-cyan-500);
    background-color: var(--color-cyan-50);
    color: var(--color-cyan-900);
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(30.2% 0.056 229.695) 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-cyan-950) 30%, transparent);
      }
    }
    &:where(.dark, .dark *) {
      color: var(--color-cyan-100);
    }
  }
  .admonition.info .admonition-title {
    color: var(--color-cyan-800);
    &:where(.dark, .dark *) {
      color: var(--color-cyan-200);
    }
  }
  .admonition.info .admonition-title::before {
    content: "💬";
  }
  .admonition.warning {
    border-color: var(--color-yellow-500);
    background-color: var(--color-yellow-50);
    color: var(--color-yellow-900);
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(28.6% 0.066 53.813) 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-yellow-950) 30%, transparent);
      }
    }
    &:where(.dark, .dark *) {
      color: var(--color-yellow-100);
    }
  }
  .admonition.warning .admonition-title {
    color: var(--color-yellow-800);
    &:where(.dark, .dark *) {
      color: var(--color-yellow-200);
    }
  }
  .admonition.warning .admonition-title::before {
    content: "⚠️";
  }
  .admonition.tip {
    border-color: var(--color-green-500);
    background-color: var(--color-green-50);
    color: var(--color-green-900);
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(26.6% 0.065 152.934) 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-green-950) 30%, transparent);
      }
    }
    &:where(.dark, .dark *) {
      color: var(--color-green-100);
    }
  }
  .admonition.tip .admonition-title {
    color: var(--color-green-800);
    &:where(.dark, .dark *) {
      color: var(--color-green-200);
    }
  }
  .admonition.tip .admonition-title::before {
    content: "💡";
  }
  .admonition.success {
    border-color: var(--color-emerald-500);
    background-color: var(--color-emerald-50);
    color: var(--color-emerald-900);
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(26.2% 0.051 172.552) 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-emerald-950) 30%, transparent);
      }
    }
    &:where(.dark, .dark *) {
      color: var(--color-emerald-100);
    }
  }
  .admonition.success .admonition-title {
    color: var(--color-emerald-800);
    &:where(.dark, .dark *) {
      color: var(--color-emerald-200);
    }
  }
  .admonition.success .admonition-title::before {
    content: "✅";
  }
  .admonition.important {
    border-color: var(--color-purple-500);
    background-color: var(--color-purple-50);
    color: var(--color-purple-900);
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(29.1% 0.149 302.717) 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-purple-950) 30%, transparent);
      }
    }
    &:where(.dark, .dark *) {
      color: var(--color-purple-100);
    }
  }
  .admonition.important .admonition-title {
    color: var(--color-purple-800);
    &:where(.dark, .dark *) {
      color: var(--color-purple-200);
    }
  }
  .admonition.important .admonition-title::before {
    content: "❗";
  }
  .admonition.caution {
    border-color: var(--color-red-500);
    background-color: var(--color-red-50);
    color: var(--color-red-900);
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(25.8% 0.092 26.042) 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-red-950) 30%, transparent);
      }
    }
    &:where(.dark, .dark *) {
      color: var(--color-red-100);
    }
  }
  .admonition.caution .admonition-title {
    color: var(--color-red-800);
    &:where(.dark, .dark *) {
      color: var(--color-red-200);
    }
  }
  .admonition.caution .admonition-title::before {
    content: "🚫";
  }
  .admonition.example {
    border-color: var(--color-indigo-500);
    background-color: var(--color-indigo-50);
    color: var(--color-indigo-900);
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(25.7% 0.09 281.288) 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-indigo-950) 30%, transparent);
      }
    }
    &:where(.dark, .dark *) {
      color: var(--color-indigo-100);
    }
  }
  .admonition.example .admonition-title {
    color: var(--color-indigo-800);
    &:where(.dark, .dark *) {
      color: var(--color-indigo-200);
    }
  }
  .admonition.example .admonition-title::before {
    content: "📋";
  }
  .admonition.devnote {
    border-color: var(--color-orange-500);
    background-color: var(--color-orange-50);
    color: var(--color-orange-900);
    &:where(.dark, .dark *) {
      background-color: color-mix(in srgb, oklch(26.6% 0.079 36.259) 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-orange-950) 30%, transparent);
      }
    }
    &:where(.dark, .dark *) {
      color: var(--color-orange-100);
    }
  }
  .admonition.devnote .admonition-title {
    color: var(--color-orange-800);
    &:where(.dark, .dark *) {
      color: var(--color-orange-200);
    }
  }
  .admonition.devnote .admonition-title::before {
    content: "🔧";
  }
  @media (max-width: 640px) {
    .admonition {
      padding: calc(var(--spacing) * 3);
      font-size: var(--text-xs);
      line-height: var(--tw-leading, var(--text-xs--line-height));
    }
    .admonition-title {
      font-size: var(--text-xs);
      line-height: var(--tw-leading, var(--text-xs--line-height));
    }
    .admonition-content {
      font-size: var(--text-xs);
      line-height: var(--tw-leading, var(--text-xs--line-height));
    }
  }
}
@layer components {
  .alert-base {
    --alert-status-color: var(--color-info);
    --alert-bg: oklch(
      from var(--alert-status-color) calc(l + 0.35) calc(c * 0.3) h
    );
    --alert-text: oklch(
      from var(--alert-status-color) calc(l - 0.25) calc(c * 1.2) h
    );
    --alert-border: oklch(
      from var(--alert-status-color) calc(l + 0.05) calc(c * 0.8) h
    );
    --alert-accent: var(--alert-status-color);
    --alert-shadow: 0 1px 3px oklch(
      from var(--alert-bg) calc(l - 0.2) c h / 0.1
    );
    --alert-shadow-hover: 0 2px 6px oklch(
      from var(--alert-bg) calc(l - 0.25) c h / 0.15
    );
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 1rem;
    border-radius: 0.5rem;
    border: 1px solid var(--alert-border);
    border-left: 4px solid var(--alert-accent);
    background-color: var(--alert-bg);
    color: var(--alert-text);
    box-shadow: var(--alert-shadow);
    transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
    font-size: 0.875rem;
    line-height: 1.5rem;
  }
  .alert-status-success {
    --alert-status-color: var(--color-success);
  }
  .alert-status-warning {
    --alert-status-color: var(--color-warning);
    --alert-text: oklch(
      from var(--alert-status-color) calc(l - 0.35) calc(c * 1.3) h
    );
  }
  .alert-status-danger {
    --alert-status-color: var(--color-danger);
  }
  .alert-status-info {
    --alert-status-color: var(--color-info);
  }
  .alert-status-neutral {
    --alert-status-color: var(--color-text-secondary);
  }
  .alert-style-filled {
    --alert-bg: var(--alert-status-color);
    --alert-text: oklch(
      from var(--alert-status-color) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
    --alert-border: oklch(
      from var(--alert-status-color) calc(l - 0.1) calc(c * 1.1) h
    );
    --alert-accent: oklch(
      from var(--alert-status-color) calc(l - 0.15) calc(c * 1.2) h
    );
  }
  .alert-style-outline {
    --alert-bg: oklch(
      from var(--alert-status-color) l c h / 0.05
    );
    --alert-text: oklch(
      from var(--alert-status-color) calc(l - 0.15) calc(c * 1.1) h
    );
    --alert-border: oklch(
      from var(--alert-status-color) calc(l + 0.05) calc(c * 0.9) h
    );
    border-width: 2px;
    border-left-width: 4px;
  }
  .alert-style-subtle {
    --alert-bg: oklch(
      from var(--alert-status-color) l c h / 0.08
    );
    --alert-text: oklch(
      from var(--alert-status-color) calc(l - 0.2) calc(c * 1.0) h
    );
    --alert-border: oklch(
      from var(--alert-status-color) l c h / 0.15
    );
    --alert-accent: oklch(
      from var(--alert-status-color) l c h / 0.4
    );
  }
  .alert-style-banner {
    border-radius: 0;
    border-left-width: 0;
    border-top: 4px solid var(--alert-accent);
    --alert-shadow: 0 2px 8px oklch(
      from var(--alert-bg) calc(l - 0.25) c h / 0.15
    );
  }
  .alert-style-gradient {
    --alert-gradient-start: var(--alert-bg);
    --alert-gradient-end: oklch(
      from var(--alert-bg) calc(l + 0.05) calc(c * 1.1) calc(h + 10)
    );
    background: linear-gradient( 135deg, var(--alert-gradient-start) 0%, var(--alert-gradient-end) 100% );
    border-left-width: 6px;
  }
  .alert-size-sm {
    padding: 0.75rem;
    gap: 0.5rem;
    font-size: 0.75rem;
    line-height: 1.25rem;
    border-radius: 0.375rem;
    border-left-width: 3px;
  }
  .alert-size-lg {
    padding: 1.25rem;
    gap: 1rem;
    font-size: 1rem;
    line-height: 1.75rem;
    border-radius: 0.75rem;
    border-left-width: 6px;
    --alert-shadow: 0 2px 6px oklch(
      from var(--alert-bg) calc(l - 0.2) c h / 0.12
    );
  }
  .alert-icon {
    --icon-color: oklch(
      from var(--alert-status-color) calc(l - 0.05) calc(c * 1.1) h
    );
    flex-shrink: 0;
    width: 1.25rem;
    height: 1.25rem;
    color: var(--icon-color);
    .alert-size-sm & {
      width: 1rem;
      height: 1rem;
    }
    .alert-size-lg & {
      width: 1.5rem;
      height: 1.5rem;
    }
  }
  .alert-content {
    flex: 1;
    min-width: 0;
  }
  .alert-title {
    font-weight: 600;
    margin-bottom: 0.25rem;
    color: oklch( from var(--alert-text) calc(l - 0.1) calc(c * 1.1) h );
    .alert-size-sm & {
      font-size: 0.875rem;
      margin-bottom: 0.25rem;
    }
    .alert-size-lg & {
      font-size: 1.125rem;
      margin-bottom: 0.5rem;
    }
  }
  .alert-description {
    color: var(--alert-text);
    .alert-size-lg & {
      line-height: 1.625;
    }
  }
  .alert-actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.75rem;
    .alert-size-sm & {
      margin-top: 0.5rem;
      gap: 0.5rem;
    }
    .alert-size-lg & {
      margin-top: 1rem;
      gap: 0.75rem;
    }
  }
  .alert-action-button {
    --button-color: var(--alert-status-color);
    --button-text: oklch(
      from var(--button-color) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
    --button-hover: oklch(
      from var(--button-color) calc(l - 0.08) calc(c * 1.05) h
    );
    background-color: var(--button-color);
    color: var(--button-text);
    border: 1px solid var(--button-color);
    padding: 0.5rem 0.75rem;
    border-radius: 0.375rem;
    font-size: 0.75rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 150ms ease-out;
    &:hover {
      background-color: var(--button-hover);
      border-color: var(--button-hover);
    }
    &:focus-visible {
      outline: 2px solid oklch( from var(--button-color) l c h / 0.5 );
      outline-offset: 2px;
    }
  }
  .alert-action-secondary {
    --button-color: transparent;
    --button-text: var(--alert-status-color);
    --button-hover: oklch(
      from var(--alert-status-color) l c h / 0.08
    );
    background-color: var(--button-color);
    color: var(--button-text);
    border: 1px solid oklch( from var(--alert-status-color) l c h / 0.3 );
  }
  .alert-dismissible {
    position: relative;
    padding-right: 3rem;
  }
  .alert-close-button {
    --close-color: oklch(
      from var(--alert-text) calc(l + 0.1) calc(c * 0.8) h
    );
    --close-hover-color: oklch(
      from var(--alert-text) calc(l - 0.1) calc(c * 1.2) h
    );
    --close-hover-bg: oklch(
      from var(--alert-status-color) l c h / 0.15
    );
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    width: 1.5rem;
    height: 1.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 0.375rem;
    color: var(--close-color);
    cursor: pointer;
    transition: all 150ms ease-out;
    border: none;
    background: transparent;
    &:hover {
      color: var(--close-hover-color);
      background-color: var(--close-hover-bg);
    }
    &:focus-visible {
      outline: 2px solid oklch( from var(--alert-status-color) l c h / 0.5 );
      outline-offset: 1px;
    }
    .alert-size-sm & {
      top: 0.5rem;
      right: 0.5rem;
      width: 1.25rem;
      height: 1.25rem;
    }
    .alert-size-lg & {
      top: 1rem;
      right: 1rem;
      width: 1.75rem;
      height: 1.75rem;
    }
  }
  .alert-enter {
    animation: alert-slide-in 300ms cubic-bezier(0.4, 0, 0.2, 1);
  }
  @keyframes alert-slide-in {
    from {
      opacity: 0;
      transform: translateY(-8px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
  .alert-exit {
    animation: alert-slide-out 250ms cubic-bezier(0.4, 0, 0.2, 1) forwards;
  }
  @keyframes alert-slide-out {
    from {
      opacity: 1;
      transform: translateY(0);
      max-height: 200px;
    }
    to {
      opacity: 0;
      transform: translateY(-8px);
      max-height: 0;
      padding-top: 0;
      padding-bottom: 0;
      margin-top: 0;
      margin-bottom: 0;
    }
  }
  .alert-pulse {
    animation: alert-pulse 2s ease-in-out infinite;
  }
  @keyframes alert-pulse {
    0%, 100% {
      box-shadow: var(--alert-shadow);
    }
    50% {
      box-shadow: var(--alert-shadow), 0 0 15px oklch(from var(--alert-accent) l c h / 0.3);
    }
  }
  .alert-fixed-top {
    position: fixed;
    top: 1rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 50;
    max-width: calc(100vw - 2rem);
    min-width: 20rem;
  }
  .alert-fixed-bottom {
    position: fixed;
    bottom: 1rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 50;
    max-width: calc(100vw - 2rem);
    min-width: 20rem;
  }
  .alert-fixed-corner {
    position: fixed;
    top: 1rem;
    right: 1rem;
    z-index: 50;
    max-width: 24rem;
  }
  @media (prefers-contrast: high) {
    .alert-base {
      border-width: 2px;
      border-left-width: 6px;
      --alert-text: oklch(
        from var(--alert-status-color) calc(l > 0.5 ? 0.1 : 0.9) c h
      );
    }
    .alert-style-outline {
      border-width: 3px;
      border-left-width: 6px;
    }
    .alert-style-subtle {
      --alert-bg: oklch(
        from var(--alert-status-color) l c h / 0.15
      );
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .alert-base {
      transition: none;
    }
    .alert-enter, .alert-exit, .alert-pulse {
      animation: none;
    }
  }
  .alert-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .alert-container {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    max-width: 100%;
  }
  .alert-container-horizontal {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
  }
  .alert-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    .alert-base {
      margin-bottom: 0;
    }
    .alert-base + .alert-base {
      border-top-left-radius: 0;
      border-top-right-radius: 0;
      border-top: none;
    }
    .alert-base:not(:last-child) {
      border-bottom-left-radius: 0;
      border-bottom-right-radius: 0;
    }
  }
  .alert-color-override {
    --alert-status-color: var(--color-override);
  }
  .alert-shadow-none {
    --alert-shadow: none;
    --alert-shadow-hover: none;
  }
  .alert-shadow-soft {
    --alert-shadow: 0 1px 3px oklch(
      from var(--alert-bg) calc(l - 0.15) c h / 0.08
    );
  }
  .alert-shadow-dramatic {
    --alert-shadow: 0 4px 12px oklch(
      from var(--alert-bg) calc(l - 0.25) c h / 0.2
    );
  }
  .alert-compact {
    padding: 0.5rem 0.75rem;
    gap: 0.5rem;
  }
  .alert-spacious {
    padding: 1.5rem 2rem;
    gap: 1.25rem;
  }
  .alert-border-none {
    border: none;
    border-left: 4px solid var(--alert-accent);
  }
  .alert-border-full {
    border: 2px solid var(--alert-border);
    border-left: 6px solid var(--alert-accent);
  }
}
@layer components {
  .badge-base {
    --badge-color: var(--color-brand-primary);
    --badge-bg: var(--badge-color);
    --badge-text: oklch(
      from var(--badge-color) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
    --badge-border: oklch(
      from var(--badge-color) calc(l - 0.10) calc(c * 1.1) h
    );
    --badge-shadow: 0 1px 3px oklch(
      from var(--badge-color) l c h / 0.2
    );
    --badge-glow: 0 0 8px oklch(
      from var(--badge-color) l c h / 0.3
    );
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem 0.75rem;
    font-size: 0.75rem;
    font-weight: 500;
    line-height: 1rem;
    border-radius: 9999px;
    border: 1px solid var(--badge-border);
    background-color: var(--badge-bg);
    color: var(--badge-text);
    box-shadow: var(--badge-shadow);
    transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
    letter-spacing: 0.025em;
    white-space: nowrap;
  }
  .badge-intent-primary {
    --badge-color: var(--color-brand-primary);
  }
  .badge-intent-secondary {
    --badge-color: oklch(
      from var(--color-brand-primary) calc(l + 0.20) calc(c * 0.7) h
    );
    --badge-bg: oklch(
      from var(--badge-color) calc(l + 0.30) calc(c * 0.3) h
    );
    --badge-text: oklch(
      from var(--color-brand-primary) calc(l - 0.15) calc(c * 1.1) h
    );
  }
  .badge-intent-success {
    --badge-color: var(--color-success);
  }
  .badge-intent-warning {
    --badge-color: var(--color-warning);
  }
  .badge-intent-danger {
    --badge-color: var(--color-danger);
  }
  .badge-intent-info {
    --badge-color: var(--color-info);
  }
  .badge-intent-neutral {
    --badge-color: var(--color-text-tertiary);
  }
  .badge-style-outline {
    --badge-bg: transparent;
    --badge-text: var(--badge-color);
    --badge-border: oklch(
      from var(--badge-color) calc(l + 0.05) calc(c * 0.9) h
    );
    --badge-shadow: none;
    border-width: 1.5px;
    &:hover {
      --badge-bg: oklch(
        from var(--badge-color) l c h / 0.08
      );
      --badge-border: oklch(
        from var(--badge-color) calc(l - 0.05) calc(c * 1.1) h
      );
    }
  }
  .badge-style-soft {
    --badge-bg: oklch(
      from var(--badge-color) l c h / 0.12
    );
    --badge-text: oklch(
      from var(--badge-color) calc(l - 0.15) calc(c * 1.2) h
    );
    --badge-border: oklch(
      from var(--badge-color) l c h / 0.2
    );
    --badge-shadow: none;
  }
  .badge-style-ghost {
    --badge-bg: transparent;
    --badge-text: oklch(
      from var(--badge-color) calc(l - 0.05) calc(c * 1.1) h
    );
    --badge-border: transparent;
    --badge-shadow: none;
    padding: 0.25rem 0.5rem;
  }
  .badge-style-gradient {
    --badge-gradient-start: var(--badge-color);
    --badge-gradient-end: oklch(
      from var(--badge-color) calc(l + 0.10) calc(c * 1.1) calc(h + 20)
    );
    --badge-text: oklch(
      from var(--badge-color) calc(l > 0.5 ? 0.15 : 0.85) c h
    );
    background: linear-gradient( 135deg, var(--badge-gradient-start) 0%, var(--badge-gradient-end) 100% );
    border: none;
  }
  .badge-style-glow {
    --badge-shadow: var(--badge-glow);
    &:hover {
      --badge-shadow: 0 0 12px oklch(
        from var(--badge-color) l c h / 0.4
      );
    }
  }
  .badge-size-xs {
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    line-height: .75rem;
    --badge-shadow: 0 1px 2px oklch(
      from var(--badge-color) l c h / 0.15
    );
  }
  .badge-size-sm {
    padding: 0.25rem 0.5rem;
    font-size: 0.75rem;
    line-height: 1rem;
    --badge-shadow: 0 1px 3px oklch(
      from var(--badge-color) l c h / 0.18
    );
  }
  .badge-size-lg {
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    line-height: 1.25rem;
    --badge-shadow: 0 2px 4px oklch(
      from var(--badge-color) l c h / 0.25
    );
  }
  .badge-size-xl {
    padding: 0.5rem 1rem;
    font-size: 1rem;
    line-height: 1.5rem;
    border-radius: 0.5rem;
    --badge-shadow: 0 3px 6px oklch(
      from var(--badge-color) l c h / 0.3
    );
  }
  .badge-clickable {
    cursor: pointer;
    user-select: none;
    --badge-hover-bg: oklch(
      from var(--badge-bg) calc(l - 0.08) calc(c * 1.05) h
    );
    --badge-active-bg: oklch(
      from var(--badge-bg) calc(l - 0.12) calc(c * 1.1) h
    );
    --badge-hover-shadow: 0 2px 6px oklch(
      from var(--badge-color) l c h / 0.3
    );
    &:hover {
      background-color: var(--badge-hover-bg);
      box-shadow: var(--badge-hover-shadow);
    }
    &:active {
      background-color: var(--badge-active-bg);
      box-shadow: var(--badge-shadow);
    }
    &:focus-visible {
      outline: 2px solid oklch( from var(--badge-color) l c h / 0.5 );
      outline-offset: 2px;
    }
  }
  .badge-removable {
    padding-right: 0.25rem;
    gap: 0.25rem;
    .badge-close {
      --close-color: oklch(
        from var(--badge-text) calc(l + 0.10) calc(c * 0.8) h
      );
      --close-hover-color: oklch(
        from var(--badge-text) calc(l - 0.10) calc(c * 1.2) h
      );
      --close-hover-bg: oklch(
        from var(--badge-text) l c h / 0.15
      );
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 1rem;
      height: 1rem;
      border-radius: 9999px;
      color: var(--close-color);
      cursor: pointer;
      transition: all 150ms ease-out;
      font-size: 0.75rem;
      font-weight: 700;
      &:hover {
        color: var(--close-hover-color);
        background-color: var(--close-hover-bg);
      }
      &:focus-visible {
        outline: 1px solid var(--close-hover-color);
        outline-offset: 1px;
      }
    }
  }
  .badge-notification {
    position: relative;
    &::before {
      content: '';
      position: absolute;
      inset: -2px;
      border-radius: 9999px;
      background: oklch( from var(--badge-color) l c h / 0.4 );
      animation: badge-pulse 2s ease-in-out infinite;
    }
  }
  @keyframes badge-pulse {
    0%, 100% {
      transform: scale(1);
      opacity: 1;
    }
    50% {
      transform: scale(1.1);
      opacity: 0.7;
    }
  }
  .badge-status-indicator {
    position: relative;
    &::before {
      content: '';
      position: absolute;
      top: -2px;
      right: -2px;
      width: 8px;
      height: 8px;
      border-radius: 9999px;
      background: var(--badge-color);
      border: 2px solid var(--color-background-primary);
    }
  }
  .badge-count {
    min-width: 1.25rem;
    height: 1.25rem;
    padding: 0 0.25rem;
    border-radius: 9999px;
    font-weight: 700;
    font-size: 0.75rem;
    --badge-shadow: 0 2px 4px oklch(
      from var(--badge-color) l c h / 0.25
    );
  }
  .badge-dot {
    width: 0.5rem;
    height: 0.5rem;
    min-width: 0.5rem;
    padding: 0;
    border-radius: 9999px;
    --badge-shadow: 0 1px 2px oklch(
      from var(--badge-color) l c h / 0.3
    );
  }
  .badge-with-icon {
    gap: 0.25rem;
    .badge-icon {
      width: 0.75rem;
      height: 0.75rem;
      flex-shrink: 0;
    }
    &.badge-size-xs .badge-icon {
      width: 0.75rem;
      height: 0.75rem;
    }
    &.badge-size-lg .badge-icon {
      width: 1rem;
      height: 1rem;
    }
    &.badge-size-xl .badge-icon {
      width: 1.25rem;
      height: 1.25rem;
    }
  }
  .badge-icon-only {
    padding: 0.25rem;
    aspect-ratio: 1;
    .badge-icon {
      width: 0.75rem;
      height: 0.75rem;
    }
    &.badge-size-xs {
      padding: 0.25rem;
      .badge-icon {
        width: 0.75rem;
        height: 0.75rem;
      }
    }
    &.badge-size-lg {
      padding: 0.5rem;
      .badge-icon {
        width: 1rem;
        height: 1rem;
      }
    }
  }
  @media (prefers-contrast: high) {
    .badge-base {
      border-width: 2px;
      font-weight: 600;
      --badge-text: oklch(
        from var(--badge-color) calc(l > 0.5 ? 0.10 : 0.90) c h
      );
    }
    .badge-style-outline {
      border-width: 3px;
    }
    .badge-style-soft {
      --badge-bg: oklch(
        from var(--badge-color) l c h / 0.2
      );
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .badge-base, .badge-clickable {
      transition: none;
    }
    .badge-clickable:hover {
      transform: none;
    }
    .badge-notification::before {
      animation: none;
    }
  }
  .badge-positioned {
    position: absolute;
    top: 0;
    right: 0;
    transform: translate(50%, -50%);
    z-index: 10;
  }
  .badge-positioned-bottom {
    top: auto;
    bottom: 0;
    transform: translate(50%, 50%);
  }
  .badge-positioned-left {
    right: auto;
    left: 0;
    transform: translate(-50%, -50%);
  }
  .badge-group {
    display: inline-flex;
    gap: 0.25rem;
    align-items: center;
    flex-wrap: wrap;
  }
  .badge-group-vertical {
    flex-direction: column;
    align-items: flex-start;
  }
  .badge-color-override {
    --badge-color: var(--color-override);
  }
  .badge-shadow-none {
    --badge-shadow: none;
  }
  .badge-shadow-soft {
    --badge-shadow: 0 1px 3px oklch(
      from var(--badge-color) l c h / 0.15
    );
  }
  .badge-shadow-dramatic {
    --badge-shadow: 0 4px 12px oklch(
      from var(--badge-color) l c h / 0.4
    );
  }
}
@layer components {
  .tooltip {
    position: relative;
    display: inline-block;
  }
  .tooltip-content {
    --tooltip-bg: var(--color-text-primary);
    --tooltip-text: oklch(from var(--tooltip-bg) calc(l > 0.5 ? 0.15 : 0.85) c h);
    --tooltip-border: oklch(from var(--tooltip-bg) calc(l - 0.1) calc(c * 1.1) h);
    --tooltip-shadow: 0 4px 12px oklch(from var(--tooltip-bg) l c h / 0.25);
    --tooltip-arrow-color: var(--tooltip-bg);
    --tooltip-arrow-border: var(--tooltip-border);
    position: absolute;
    z-index: 60;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.25rem;
    border-radius: 0.375rem;
    white-space: nowrap;
    pointer-events: none;
    user-select: none;
    background: var(--tooltip-bg);
    color: var(--tooltip-text);
    border: 1px solid var(--tooltip-border);
    box-shadow: var(--tooltip-shadow);
    opacity: 0;
    visibility: hidden;
    transform: scale(0.9);
    transition: all 200ms cubic-bezier(0.4, 0, 0.2, 1);
    .tooltip:hover &, .tooltip:focus-within &, &.tooltip-show {
      opacity: 1;
      visibility: visible;
      transform: scale(1);
    }
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
  }
  .tooltip-top {
    .tooltip-content {
      bottom: 100%;
      left: 50%;
      transform: translateX(-50%) scale(0.9);
      margin-bottom: 0.5rem;
      .tooltip:hover &, .tooltip:focus-within &, &.tooltip-show {
        transform: translateX(-50%) scale(1);
      }
      &::after {
        content: '';
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translateX(-50%);
        width: 0;
        height: 0;
        border-left: 6px solid transparent;
        border-right: 6px solid transparent;
        border-top: 6px solid var(--tooltip-arrow-color);
      }
      &::before {
        content: '';
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translateX(-50%);
        width: 0;
        height: 0;
        border-left: 7px solid transparent;
        border-right: 7px solid transparent;
        border-top: 7px solid var(--tooltip-arrow-border);
        z-index: -1;
      }
    }
  }
  .tooltip-bottom {
    .tooltip-content {
      top: 100%;
      left: 50%;
      transform: translateX(-50%) scale(0.9);
      margin-top: 0.5rem;
      .tooltip:hover &, .tooltip:focus-within &, &.tooltip-show {
        transform: translateX(-50%) scale(1);
      }
      &::after {
        content: '';
        position: absolute;
        bottom: 100%;
        left: 50%;
        transform: translateX(-50%);
        width: 0;
        height: 0;
        border-left: 6px solid transparent;
        border-right: 6px solid transparent;
        border-bottom: 6px solid var(--tooltip-arrow-color);
      }
      &::before {
        content: '';
        position: absolute;
        bottom: 100%;
        left: 50%;
        transform: translateX(-50%);
        width: 0;
        height: 0;
        border-left: 7px solid transparent;
        border-right: 7px solid transparent;
        border-bottom: 7px solid var(--tooltip-arrow-border);
        z-index: -1;
      }
    }
  }
  .tooltip-left {
    .tooltip-content {
      right: 100%;
      top: 50%;
      transform: translateY(-50%) scale(0.9);
      margin-right: 0.5rem;
      .tooltip:hover &, .tooltip:focus-within &, &.tooltip-show {
        transform: translateY(-50%) scale(1);
      }
      &::after {
        content: '';
        position: absolute;
        left: 100%;
        top: 50%;
        transform: translateY(-50%);
        width: 0;
        height: 0;
        border-top: 6px solid transparent;
        border-bottom: 6px solid transparent;
        border-left: 6px solid var(--tooltip-arrow-color);
      }
      &::before {
        content: '';
        position: absolute;
        left: 100%;
        top: 50%;
        transform: translateY(-50%);
        width: 0;
        height: 0;
        border-top: 7px solid transparent;
        border-bottom: 7px solid transparent;
        border-left: 7px solid var(--tooltip-arrow-border);
        z-index: -1;
      }
    }
  }
  .tooltip-right {
    .tooltip-content {
      left: 100%;
      top: 50%;
      transform: translateY(-50%) scale(0.9);
      margin-left: 0.5rem;
      .tooltip:hover &, .tooltip:focus-within &, &.tooltip-show {
        transform: translateY(-50%) scale(1);
      }
      &::after {
        content: '';
        position: absolute;
        right: 100%;
        top: 50%;
        transform: translateY(-50%);
        width: 0;
        height: 0;
        border-top: 6px solid transparent;
        border-bottom: 6px solid transparent;
        border-right: 6px solid var(--tooltip-arrow-color);
      }
      &::before {
        content: '';
        position: absolute;
        right: 100%;
        top: 50%;
        transform: translateY(-50%);
        width: 0;
        height: 0;
        border-top: 7px solid transparent;
        border-bottom: 7px solid transparent;
        border-right: 7px solid var(--tooltip-arrow-border);
        z-index: -1;
      }
    }
  }
  .tooltip-size-xs {
    .tooltip-content {
      padding: 0.25rem 0.5rem;
      font-size: 0.75rem;
      line-height: 1rem;
      border-radius: 0.25rem;
      --tooltip-shadow: 0 2px 6px oklch(from var(--tooltip-bg) l c h / 0.2);
    }
  }
  .tooltip-size-sm {
    .tooltip-content {
      padding: 0.5rem 0.75rem;
      font-size: 0.875rem;
      line-height: 1.25rem;
      --tooltip-shadow: 0 3px 8px oklch(from var(--tooltip-bg) l c h / 0.22);
    }
  }
  .tooltip-size-lg {
    .tooltip-content {
      padding: 0.75rem 1rem;
      font-size: 1rem;
      line-height: 1.5rem;
      border-radius: 0.5rem;
      --tooltip-shadow: 0 6px 16px oklch(from var(--tooltip-bg) l c h / 0.3);
    }
  }
  .tooltip-size-xl {
    .tooltip-content {
      padding: 1rem 1.25rem;
      font-size: 1.125rem;
      line-height: 1.75rem;
      border-radius: 0.75rem;
      --tooltip-shadow: 0 8px 20px oklch(from var(--tooltip-bg) l c h / 0.35);
    }
  }
  .tooltip-intent-primary {
    .tooltip-content {
      --tooltip-bg: var(--color-brand-primary);
    }
  }
  .tooltip-intent-success {
    .tooltip-content {
      --tooltip-bg: var(--color-success);
    }
  }
  .tooltip-intent-warning {
    .tooltip-content {
      --tooltip-bg: var(--color-warning);
      --tooltip-text: oklch(from var(--tooltip-bg) calc(l > 0.6 ? 0.1 : 0.9) c h);
    }
  }
  .tooltip-intent-danger {
    .tooltip-content {
      --tooltip-bg: var(--color-danger);
    }
  }
  .tooltip-intent-info {
    .tooltip-content {
      --tooltip-bg: var(--color-info);
    }
  }
  .tooltip-intent-light {
    .tooltip-content {
      --tooltip-bg: var(--color-background-elevated);
      --tooltip-text: var(--color-text-primary);
      --tooltip-border: var(--color-border-default);
      --tooltip-shadow: 0 4px 12px oklch(from var(--tooltip-bg) calc(l - 0.3) c h / 0.15);
    }
  }
  .tooltip-style-outline {
    .tooltip-content {
      --tooltip-bg: transparent;
      --tooltip-text: var(--color-text-primary);
      --tooltip-border: var(--color-border-default);
      border-width: 2px;
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
      background: oklch(from var(--color-background-primary) l c h / 0.9);
    }
  }
  .tooltip-style-soft {
    .tooltip-content {
      --tooltip-bg: oklch(from var(--color-text-primary) l c h / 0.9);
      --tooltip-border: transparent;
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
    }
  }
  .tooltip-style-minimal {
    .tooltip-content {
      --tooltip-border: transparent;
      --tooltip-shadow: none;
      padding: 0.25rem 0.5rem;
      border-radius: 0.25rem;
    }
  }
  .tooltip-multiline {
    .tooltip-content {
      white-space: normal;
      max-width: 16rem;
      text-align: left;
      line-height: 1.625;
      padding: 0.75rem 1rem;
    }
  }
  .tooltip-multiline-sm {
    .tooltip-content {
      max-width: 12rem;
    }
  }
  .tooltip-multiline-lg {
    .tooltip-content {
      max-width: 20rem;
    }
  }
  .tooltip-rich {
    .tooltip-content {
      padding: 1rem;
      text-align: left;
      white-space: normal;
      max-width: 18rem;
      --tooltip-shadow: 0 8px 25px oklch(from var(--tooltip-bg) l c h / 0.3);
    }
    .tooltip-title {
      font-weight: 600;
      margin-bottom: 0.25rem;
      color: oklch(from var(--tooltip-text) calc(l - 0.05) calc(c * 1.1) h);
    }
    .tooltip-description {
      font-size: 0.875rem;
      line-height: 1.625;
      opacity: 0.9;
    }
    .tooltip-meta {
      font-size: 0.75rem;
      margin-top: 0.5rem;
      opacity: 0.8;
      border-top: 1px solid oklch(from var(--tooltip-text) l c h / 0.2);
      padding-top: 0.5rem;
    }
  }
  .tooltip-interactive {
    .tooltip-content {
      pointer-events: auto;
      cursor: default;
      --tooltip-shadow: 0 8px 25px oklch(from var(--tooltip-bg) l c h / 0.25);
      &:hover {
        --tooltip-shadow: 0 12px 30px oklch(from var(--tooltip-bg) l c h / 0.3);
        transform: scale(1.02);
      }
    }
    .tooltip-content:hover {
      opacity: 1;
      visibility: visible;
    }
  }
  .tooltip-clickable {
    .tooltip-content {
      pointer-events: auto;
      cursor: pointer;
      transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
      &:hover {
        background: oklch(from var(--tooltip-bg) calc(l - 0.05) calc(c * 1.05) h);
      }
      &:active {
        transform: scale(0.98);
      }
    }
  }
  .tooltip-delay-short {
    .tooltip-content {
      transition-delay: 100ms;
    }
  }
  .tooltip-delay-normal {
    .tooltip-content {
      transition-delay: 300ms;
    }
  }
  .tooltip-delay-long {
    .tooltip-content {
      transition-delay: 600ms;
    }
  }
  .tooltip-duration-fast {
    .tooltip-content {
      transition-duration: 100ms;
    }
  }
  .tooltip-duration-slow {
    .tooltip-content {
      transition-duration: 400ms;
    }
  }
  @media (prefers-contrast: high) {
    .tooltip-content {
      border-width: 2px;
      --tooltip-text: oklch(from var(--tooltip-bg) calc(l > 0.5 ? 0.05 : 0.95) c h);
      --tooltip-shadow: 0 6px 16px oklch(from var(--tooltip-bg) l c h / 0.4);
    }
    .tooltip-style-outline .tooltip-content {
      border-width: 3px;
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .tooltip-content {
      transition: opacity 150ms ease;
      transform: none;
    }
    .tooltip:hover .tooltip-content, .tooltip:focus-within .tooltip-content, .tooltip-content.tooltip-show {
      transform: none;
    }
  }
  .tooltip-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  @media (max-width: 40rem) {
    .tooltip-content {
      max-width: calc(100vw - 2rem);
      font-size: 0.875rem;
    }
    .tooltip-multiline .tooltip-content {
      max-width: calc(100vw - 1rem);
    }
    .tooltip-rich .tooltip-content {
      max-width: calc(100vw - 1rem);
      padding: 0.75rem;
    }
    .tooltip-content::before, .tooltip-content::after {
      border-width: 4px;
    }
  }
  @media (hover: none) and (pointer: coarse) {
    .tooltip {
      &:active .tooltip-content {
        opacity: 1;
        visibility: visible;
        transform: scale(1);
      }
    }
    .tooltip-interactive .tooltip-content {
      min-height: 3rem;
      display: flex;
      align-items: center;
    }
  }
  .tooltip-color-override {
    .tooltip-content {
      --tooltip-bg: var(--color-override);
    }
  }
  .tooltip-shadow-none {
    .tooltip-content {
      --tooltip-shadow: none;
    }
  }
  .tooltip-shadow-soft {
    .tooltip-content {
      --tooltip-shadow: 0 2px 8px oklch(from var(--tooltip-bg) l c h / 0.15);
    }
  }
  .tooltip-shadow-dramatic {
    .tooltip-content {
      --tooltip-shadow: 0 12px 30px oklch(from var(--tooltip-bg) l c h / 0.4);
    }
  }
  .tooltip-z-high {
    .tooltip-content {
      z-index: 70;
    }
  }
  .tooltip-z-highest {
    .tooltip-content {
      z-index: 80;
    }
  }
  .tooltip-anim-bounce {
    .tooltip:hover .tooltip-content, .tooltip:focus-within .tooltip-content, .tooltip-content.tooltip-show {
      animation: tooltip-bounce 300ms cubic-bezier(0.68, -0.55, 0.265, 1.55);
    }
  }
  @keyframes tooltip-bounce {
    0% {
      transform: scale(0.8);
      opacity: 0;
    }
    50% {
      transform: scale(1.05);
      opacity: 0.8;
    }
    100% {
      transform: scale(1);
      opacity: 1;
    }
  }
  .tooltip-anim-slide {
    .tooltip-top .tooltip-content {
      transform: translateX(-50%) translateY(8px) scale(0.9);
      .tooltip:hover &, .tooltip:focus-within &, &.tooltip-show {
        transform: translateX(-50%) translateY(0) scale(1);
      }
    }
    .tooltip-bottom .tooltip-content {
      transform: translateX(-50%) translateY(-8px) scale(0.9);
      .tooltip:hover &, .tooltip:focus-within &, &.tooltip-show {
        transform: translateX(-50%) translateY(0) scale(1);
      }
    }
    .tooltip-left .tooltip-content {
      transform: translateY(-50%) translateX(8px) scale(0.9);
      .tooltip:hover &, .tooltip:focus-within &, &.tooltip-show {
        transform: translateY(-50%) translateX(0) scale(1);
      }
    }
    .tooltip-right .tooltip-content {
      transform: translateY(-50%) translateX(-8px) scale(0.9);
      .tooltip:hover &, .tooltip:focus-within &, &.tooltip-show {
        transform: translateY(-50%) translateX(0) scale(1);
      }
    }
  }
}
@layer components {
  .prose {
    max-width: 65ch;
    line-height: 1.7;
    color: var(--color-text-primary);
  }
  .prose h1, .prose h2, .prose h3, .prose h4, .prose h5, .prose h6 {
    font-weight: 600;
    line-height: 1.3;
    margin-top: 2rem;
    margin-bottom: 1rem;
    color: var(--color-text-primary);
  }
  .prose h1 {
    font-size: 1.875rem;
    margin-top: 0;
    @media (min-width: 64rem) {
      font-size: 2.25rem;
    }
  }
  .prose h2 {
    font-size: 1.5rem;
    border-bottom: 1px solid var(--color-border-default);
    padding-bottom: 0.5rem;
    @media (min-width: 64rem) {
      font-size: 1.875rem;
    }
  }
  .prose h3 {
    font-size: 1.25rem;
    @media (min-width: 64rem) {
      font-size: 1.5rem;
    }
  }
  .prose h4 {
    font-size: 1.125rem;
    @media (min-width: 64rem) {
      font-size: 1.25rem;
    }
  }
  .prose h5, .prose h6 {
    font-size: 1rem;
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
  }
  .prose p {
    margin-bottom: 1.5rem;
    font-size: 1rem;
    line-height: 1.7;
  }
  .prose p:last-child {
    margin-bottom: 0;
  }
  .prose strong, .prose b {
    font-weight: 600;
    color: var(--color-text-primary);
  }
  .prose em, .prose i {
    font-style: italic;
  }
  .prose small {
    font-size: 0.875rem;
    color: var(--color-text-tertiary, oklch(55.4% 0.046 257.417));
    font-weight: 500;
  }
  .prose a {
    color: var(--color-brand-primary);
    text-decoration: underline;
    text-decoration-color: var(--color-brand-primary-muted);
    text-underline-offset: 2px;
    transition: all 200ms;
    &:hover {
      color: var(--color-brand-secondary);
      text-decoration-color: var(--color-brand-secondary-muted);
    }
    &:focus-visible {
      outline: 2px solid var(--color-brand-primary);
      outline-offset: 2px;
      border-radius: 0.25rem;
    }
  }
  .prose table a {
    text-decoration: none;
    &:hover {
      text-decoration: none;
    }
  }
  .prose [class*="btn-"] a, .prose [class*="card-"] a, .prose .btn a, .prose button a {
    text-decoration: none;
    &:hover {
      text-decoration: none;
    }
  }
  .prose ul {
    list-style: disc;
    list-style-position: inside;
    margin-bottom: 1.5rem;
    padding-left: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .prose ul li {
    list-style: disc;
    margin-bottom: 0.5rem;
    line-height: 1.6;
    dl {
      margin-top: -theme(spacing[6]);
      margin-left: 1rem;
      dt {
        font-weight: 500;
      }
    }
  }
  .prose ol {
    list-style: none;
    margin-bottom: 1.5rem;
    padding-left: 2.5rem;
    display: flex;
    flex-direction: column;
    gap: 2rem;
    counter-reset: section;
    position: relative;
  }
  .prose ol > li {
    position: relative;
    padding-left: 0;
    margin-left: 0;
    counter-increment: section;
    margin-bottom: 1rem;
    line-height: 1.6;
    &::before {
      content: counter(section);
      position: absolute;
      left: calc(-1 * 2rem);
      top: 0.25rem;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 1.25rem;
      height: 1.25rem;
      background-color: var(--color-brand-primary);
      color: var(--color-text-on-brand);
      border-radius: 9999px;
      font-size: 0.875rem;
      font-weight: 500;
    }
    dl {
      margin-left: 0;
      margin-top: 2rem;
      margin-bottom: 1.5rem;
      dt {
        margin-top: -theme(spacing[4]);
        font-weight: 500;
      }
      &:has(dd:nth-of-type(2)) dd {
        position: relative;
        padding-left: 1.25rem;
        margin-bottom: 0.25rem;
        &::before {
          content: '•';
          position: absolute;
          left: 0;
          top: 0;
        }
      }
    }
  }
  .prose ul ul, .prose ol ol, .prose ul ol, .prose ol ul {
    margin-left: 1.25rem;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
  }
  .prose dl {
    display: block;
    margin-bottom: 1.5rem;
  }
  .prose dt {
    display: block;
    font-weight: 600;
    font-size: 1.125rem;
    color: var(--color-text-primary);
    margin-bottom: 0;
    margin-top: -theme(spacing[1]);
    line-height: 1.6;
  }
  .prose dd {
    display: block;
    margin-bottom: 1rem;
    margin-left: 0;
    color: var(--color-text-secondary);
    &:last-child {
      margin-bottom: 0;
    }
    ul {
      margin-bottom: 0;
    }
  }
  .prose dd dl {
    margin-top: 1rem;
    margin-bottom: 0.5rem;
  }
  .prose dd dt {
    font-size: 1rem;
  }
  .prose dd dd {
    margin-left: 2rem;
  }
  .prose table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1.5rem;
    font-size: 0.875rem;
  }
  .prose th {
    text-align: left;
    vertical-align: top;
    padding: 0.5rem;
    border: 1px solid var(--color-border-default);
    background-color: var(--color-background-secondary);
    font-weight: 600;
    color: var(--color-text-primary);
  }
  .prose td {
    vertical-align: top;
    padding: 0.5rem;
    border: 1px solid var(--color-border-default);
    background-color: var(--color-background-primary);
    color: var(--color-text-primary);
  }
  .prose code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.875rem;
    background-color: var(--color-background-subtle);
    color: var(--color-text-primary);
    padding: 0.25rem 0.5rem;
    border-radius: 0.375rem;
  }
  .prose pre {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.875rem;
    background-color: transparent;
    color: var(--color-text-primary);
    padding: 0.25rem;
    border-radius: 0.5rem;
    overflow-x: auto;
    margin-bottom: 1.5rem;
    code {
      background: none;
      padding: 0;
      border-radius: 0;
      color: inherit;
      border: none;
    }
  }
  .prose blockquote {
    border-left: 4px solid var(--color-brand-primary);
    padding-left: 1rem;
    margin: 1.5rem 0;
    font-style: italic;
    color: var(--color-text-secondary);
  }
  .prose blockquote p {
    margin-bottom: 1rem;
  }
  .prose blockquote p:last-child {
    margin-bottom: 0;
  }
  .prose hr {
    border: none;
    height: 1px;
    background-color: var(--color-border-default);
    margin: 2rem 0;
  }
  .prose-size-sm {
    font-size: 0.875rem;
    line-height: 1.6;
    h1, h2, h3, h4, h5, h6 {
      margin-top: 1.5rem;
      margin-bottom: 0.75rem;
    }
    h1 {
      font-size: 1.5rem;
    }
    h2 {
      font-size: 1.25rem;
    }
    h3 {
      font-size: 1.125rem;
    }
    h4, h5, h6 {
      font-size: 1rem;
    }
  }
  .prose-size-lg {
    font-size: 1.125rem;
    line-height: 1.8;
    h1 {
      font-size: 3rem;
    }
    h2 {
      font-size: 2.25rem;
    }
    h3 {
      font-size: 1.875rem;
    }
    h4 {
      font-size: 1.5rem;
    }
    h5, h6 {
      font-size: 1.25rem;
    }
  }
  .prose-style-compact {
    p, ul, ol, dl, blockquote, pre {
      margin-bottom: 1rem;
    }
    h1, h2, h3, h4, h5, h6 {
      margin-top: 1.5rem;
      margin-bottom: 0.5rem;
    }
    ul {
      display: flex;
      flex-direction: column;
      gap: 0.5rem;
    }
    ol {
      display: flex;
      flex-direction: column;
      gap: 1rem;
    }
  }
  .prose-style-feature {
    h1, h2 {
      background: var(--gradient-brand);
      background-clip: text;
      -webkit-background-clip: text;
      color: transparent;
    }
    blockquote {
      background-color: var(--color-brand-primary-whisper);
      border-left-color: var(--color-brand-primary);
      border-radius: 0.5rem;
      padding: 1rem;
    }
  }
  .prose .list-unstyled {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    li {
      list-style: none;
      margin-left: 0;
      margin-bottom: 0;
      &::before {
        display: none;
      }
    }
  }
  .prose .list-custom {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
    li {
      list-style: none !important;
      margin-left: 0 !important;
      margin-bottom: 0 !important;
      &::before {
        display: none !important;
      }
    }
  }
  .prose .list-manual-bullets {
    list-style: disc;
    list-style-position: inside;
    li {
      list-style: disc;
      list-style-position: inside;
      margin-left: 0;
      &::before {
        display: none;
      }
    }
  }
  .prose .list-manual-numbers {
    list-style: decimal;
    list-style-position: inside;
    li {
      list-style: decimal;
      list-style-position: inside;
      margin-left: 0;
      &::before {
        display: none;
      }
    }
  }
  @media (max-width: 40rem) {
    .prose {
      font-size: 0.875rem;
    }
    .prose h1 {
      font-size: 1.5rem;
    }
    .prose h2 {
      font-size: 1.25rem;
    }
    .prose h3 {
      font-size: 1.125rem;
    }
    .prose ol {
      padding-left: 2rem;
    }
    .prose ol li::before {
      left: -theme(spacing[6]);
    }
    .prose table {
      font-size: 0.75rem;
    }
    .prose th, .prose td {
      padding: 0.25rem;
    }
  }
  @media print {
    .prose {
      color: var(--color-text-print);
      font-size: 12pt;
      line-height: 1.5;
    }
    .prose h1, .prose h2, .prose h3, .prose h4, .prose h5, .prose h6 {
      page-break-after: avoid;
      color: var(--color-text-print);
    }
    .prose blockquote {
      border-left-color: var(--color-border-print);
      background: none;
    }
    .prose code, .prose pre {
      background: var(--color-background-print);
      color: var(--color-text-print);
    }
    .prose a {
      color: var(--color-text-print);
      text-decoration: underline;
    }
  }
}
:root {
  --bg-light-gradient-1: #e01b24;
  --bg-light-gradient-2: #ed333b;
  --bg-light-gradient-3: #96aa8e;
  --bg-light-gradient-4: #7153b6;
  --bg-light-gradient-5: #ffbe6f;
  --bg-light-gradient-base: #1c71d8;
  --bg-dark-gradient-1: #802200;
  --bg-dark-gradient-2: #802200;
  --bg-dark-gradient-base: #4a0d15;
}
@layer components {
  .bg-light-gradient {
    background: radial-gradient(at 73% 0%, var(--bg-light-gradient-1) 0px, transparent 50%), radial-gradient(at 10% 98%, var(--bg-light-gradient-2) 0px, transparent 50%), radial-gradient(at 28% 57%, var(--bg-light-gradient-3) 0px, transparent 50%), radial-gradient(at 59% 67%, var(--bg-light-gradient-4) 0px, transparent 50%), radial-gradient(at 44% 74%, var(--bg-light-gradient-5) 0px, transparent 50%), var(--bg-light-gradient-base);
  }
  .bg-dark-gradient {
    background: radial-gradient(at 55% 2%, var(--bg-dark-gradient-1) 0px, transparent 50%), radial-gradient(at 29% 13%, var(--bg-dark-gradient-2) 0px, transparent 50%), var(--bg-dark-gradient-base);
  }
  .dark {
    .blog-nav-container button.blog-nav-btn.btn-base.btn-intent-secondary {
      --btn-color: oklch(27.4% 0.006 286.033);
      --btn-text-color: oklch(96.7% 0.001 286.375);
    }
    .blog-nav-container button.blog-nav-btn.btn-base.btn-intent-secondary:hover {
      --btn-color: oklch(44.2% 0.017 285.786);
      --btn-text-color: oklch(96.7% 0.001 286.375);
    }
  }
  @media (min-width: 64rem) {
    h1 {
      font-size: 2.25rem;
    }
    h2 {
      font-size: 1.875rem;
    }
    h3 {
      font-size: 1.5rem;
    }
  }
  #pagination {
    span[aria-current="page"] {
      background: var(--color-brand-primary-dark);
      color: var(--color-text-inverted-primary);
    }
    .btn-base {
      background: transparent;
      color: var(--color-text-secondary);
      border: 1px solid var(--color-border-default);
    }
    button[disabled] {
      color: var(--color-text-tertiary);
    }
  }
  .prose code {
    background-color: rgb(212, 213, 217);
    color: #312d2d;
    position: relative;
    top: -1px;
    padding-bottom: 0.1rem;
  }
  .dark .prose code {
    background-color: rgb(39, 40, 34);
    color: rgb(219, 110, 44);
  }
  .prose pre code {
    color: white !important;
  }
  .prose ol {
    gap: 1rem;
  }
  .prose ol li {
    margin-bottom: 0;
  }
  .prose ul li {
    margin-bottom: 0;
  }
  .prose ul li.task-list-item {
    list-style: none;
    padding-left: 0;
    & .task-list-item-checkbox {
      margin-right: 0.5rem;
    }
  }
}
@layer themes {
  .dark .docs-sidebar {
    background: var(--color-background-elevated);
  }
}
@layer components {
  .gallery-index-header {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
    margin-bottom: var(--spacing-8);
  }
  @media (min-width: 640px) {
    .gallery-index-header {
      flex-direction: row;
      align-items: center;
      justify-content: space-between;
    }
  }
  .gallery-index-title {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-gray-900);
    margin-bottom: var(--spacing-2);
  }
  .dark .gallery-index-title {
    color: var(--color-gray-100);
  }
  .gallery-index-description {
    font-size: var(--font-size-lg);
    color: var(--color-gray-600);
    max-width: var(--max-width-2xl);
  }
  .dark .gallery-index-description {
    color: var(--color-gray-400);
  }
  .gallery-index-controls {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    flex-shrink: 0;
  }
  .gallery-control-toggle-group {
    display: flex;
    border-radius: var(--radius-md);
    border: 1px solid var(--color-gray-300);
    overflow: hidden;
  }
  .dark .gallery-control-toggle-group {
    border-color: var(--color-gray-600);
  }
  .gallery-control-button-base {
    padding: var(--spacing-3) var(--spacing-3);
    font-size: var(--font-size-sm);
    transition-property: color, background-color;
    transition-duration: var(--transition-normal);
    transition-timing-function: var(--easing-ease-out);
    cursor: pointer;
    border: none;
    border-radius: 0;
  }
  .gallery-control-button-base:focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
    box-shadow: 0 0 0 2px var(--color-blue-500);
  }
  @media (prefers-reduced-motion: reduce) {
    .gallery-control-button-base {
      transition: none;
    }
  }
  .gallery-control-button-active {
    background-color: var(--color-blue-500);
    color: var(--color-white);
  }
  .gallery-control-button-inactive {
    background-color: var(--color-white);
    color: var(--color-gray-700);
  }
  .dark .gallery-control-button-inactive {
    background-color: var(--color-gray-800);
    color: var(--color-gray-300);
  }
  .gallery-control-button-inactive:hover {
    background-color: var(--color-gray-50);
  }
  .dark .gallery-control-button-inactive:hover {
    background-color: var(--color-gray-700);
  }
  .gallery-grid-responsive {
    display: grid;
    gap: var(--spacing-6);
    grid-template-columns: repeat(1, 1fr);
  }
  @media (min-width: 640px) {
    .gallery-grid-responsive {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  @media (min-width: 1024px) {
    .gallery-grid-responsive {
      grid-template-columns: repeat(var(--gallery-columns, 4), 1fr);
    }
  }
  @media (min-width: 1280px) {
    .gallery-grid-responsive {
      grid-template-columns: repeat(calc(var(--gallery-columns, 4) + 1), 1fr);
    }
  }
  .gallery-list-layout {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-6);
  }
  .gallery-card-base {
    display: flex;
    gap: var(--spacing-6);
    padding: var(--spacing-6);
    background-color: var(--color-white);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-gray-200);
    transition-property: box-shadow;
    transition-duration: var(--transition-normal);
    transition-timing-function: var(--easing-ease-out);
  }
  .dark .gallery-card-base {
    background-color: var(--color-gray-800);
    border-color: var(--color-gray-700);
  }
  .gallery-card-base:hover {
    box-shadow: var(--shadow-md);
  }
  .photo-item-container {
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: var(--radius-md);
    background-color: var(--color-gray-100);
    aspect-ratio: 4/3;
  }
  .dark .photo-item-container {
    background-color: var(--color-gray-800);
  }
  .photo-item-clickable {
    cursor: pointer;
    transition-property: transform, box-shadow;
    transition-duration: var(--transition-slow);
    transition-timing-function: var(--easing-ease-out);
  }
  .photo-item-clickable:hover {
    box-shadow: var(--shadow-lg);
  }
  @media (prefers-reduced-motion: reduce) {
    .photo-item-clickable {
      transition: none;
    }
    .photo-item-clickable:hover {
      transform: none;
    }
  }
  .photo-thumbnail-cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .photo-card-thumbnail {
    display: block;
    width: var(--spacing-32);
    height: var(--spacing-24);
    border-radius: var(--radius-md);
    overflow: hidden;
    background-color: var(--color-gray-100);
    flex-shrink: 0;
  }
  .dark .photo-card-thumbnail {
    background-color: var(--color-gray-700);
  }
  .photo-figure-base {
    margin-bottom: var(--spacing-6);
  }
  .photo-figure-image {
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    width: 100%;
    height: auto;
  }
  .gallery-meta-container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-4);
    font-size: var(--font-size-sm);
    color: var(--color-gray-500);
    margin-bottom: var(--spacing-6);
  }
  .dark .gallery-meta-container {
    color: var(--color-gray-400);
  }
  .gallery-meta-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-2);
  }
  .gallery-title-main {
    font-size: var(--font-size-3xl);
    font-weight: var(--font-weight-bold);
    color: var(--color-gray-900);
    margin-bottom: var(--spacing-4);
  }
  .dark .gallery-title-main {
    color: var(--color-gray-100);
  }
  .gallery-description-text {
    font-size: var(--font-size-lg);
    color: var(--color-gray-600);
    max-width: var(--max-width-3xl);
  }
  .dark .gallery-description-text {
    color: var(--color-gray-400);
  }
  .gallery-card-title {
    font-size: var(--font-size-xl);
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-900);
    margin-bottom: var(--spacing-1);
  }
  .dark .gallery-card-title {
    color: var(--color-gray-100);
  }
  .gallery-link-interactive {
    transition-property: color;
    transition-duration: var(--transition-normal);
    transition-timing-function: var(--easing-ease-out);
  }
  .gallery-link-interactive:hover {
    color: var(--color-blue-600);
  }
  .dark .gallery-link-interactive:hover {
    color: var(--color-blue-400);
  }
  .photo-caption-text {
    margin-top: var(--spacing-2);
    font-size: var(--font-size-sm);
    color: var(--color-gray-600);
    text-align: center;
  }
  .dark .photo-caption-text {
    color: var(--color-gray-400);
  }
  .photo-info-primary {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-900);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .dark .photo-info-primary {
    color: var(--color-gray-100);
  }
  .photo-info-secondary {
    font-size: var(--font-size-xs);
    color: var(--color-gray-500);
    margin-top: var(--spacing-1);
  }
  .dark .photo-info-secondary {
    color: var(--color-gray-400);
  }
  .gallery-grid-auto-fill {
    display: grid;
    gap: var(--spacing-4);
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    margin-bottom: var(--spacing-8);
  }
  .gallery-grid-simple {
    display: grid;
    gap: var(--spacing-4);
    grid-template-columns: repeat(1, 1fr);
  }
  @media (min-width: 640px) {
    .gallery-grid-simple {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  @media (min-width: 768px) {
    .gallery-grid-simple {
      grid-template-columns: repeat(3, 1fr);
    }
  }
  @media (min-width: 1024px) {
    .gallery-grid-simple {
      grid-template-columns: repeat(4, 1fr);
    }
  }
  .inline-gallery-compact {
    margin-bottom: var(--spacing-6);
  }
  @container (min-width: 768px) {
    .gallery-grid-responsive {
      grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    }
  }
  @container (min-width: 1200px) {
    .gallery-grid-responsive {
      grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    }
  }
  .gallery-header-section {
    margin-bottom: var(--spacing-8);
  }
  .photo-gallery-wrapper {
    margin-bottom: var(--spacing-8);
    contain: layout style paint;
  }
  .photo-item-interactive {
    position: relative;
    overflow: hidden;
    cursor: pointer;
  }
  .photo-item-interactive::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: black;
    opacity: 0;
    z-index: 1;
    pointer-events: none;
    transition: opacity 0.3s ease-out;
  }
  .photo-item-interactive:hover::before {
    opacity: 0.2;
  }
  .gallery-loading-state {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-8);
    color: var(--color-gray-500);
  }
  .dark .gallery-loading-state {
    color: var(--color-gray-400);
  }
  .photo-error-state {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-4);
    background-color: var(--color-red-50);
    border: 1px solid var(--color-red-200);
    border-radius: var(--radius-md);
    color: var(--color-red-800);
    margin-bottom: var(--spacing-6);
  }
  .dark .photo-error-state {
    background-color: var(--color-red-950);
    border-color: var(--color-red-800);
    color: var(--color-red-400);
  }
  .photos-nav {
    display: flex;
    gap: var(--spacing-2);
    margin-bottom: var(--spacing-6);
  }
  .photo-masonry {
    column-count: 1;
    column-gap: var(--spacing-4);
  }
  @media (min-width: 640px) {
    .photo-masonry {
      column-count: 2;
    }
  }
  @media (min-width: 768px) {
    .photo-masonry {
      column-count: 3;
    }
  }
  @media (min-width: 1024px) {
    .photo-masonry {
      column-count: 4;
    }
  }
  .photo-masonry > * {
    break-inside: avoid;
    margin-bottom: var(--spacing-4);
  }
  .gallery-page-wrapper {
    max-width: var(--max-width-7xl);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--spacing-4);
    padding-right: var(--spacing-4);
  }
  .photo-figure {
    position: relative;
    margin-bottom: var(--spacing-6);
  }
  .photo-figure:hover .photo-zoom-link {
    opacity: 1;
  }
  .photo-zoom-link {
    position: absolute;
    top: var(--spacing-2);
    right: var(--spacing-2);
    background-color: rgba(0, 0, 0, 0.5);
    color: var(--color-white);
    padding: var(--spacing-2);
    border-radius: 9999px;
    opacity: 0;
    transition: opacity 0.3s ease-out, background-color 0.3s ease-out;
  }
  .photo-zoom-link:hover {
    background-color: rgba(0, 0, 0, 0.7);
  }
  .photo-metadata-display {
    margin-top: var(--spacing-3);
    padding: var(--spacing-4);
    background-color: var(--color-gray-50);
    border-radius: var(--radius-md);
  }
  .dark .photo-metadata-display {
    background-color: var(--color-gray-800);
  }
  .metadata-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: var(--spacing-3);
    font-size: var(--font-size-sm);
  }
  @media (min-width: 768px) {
    .metadata-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }
  .metadata-item {
    display: flex;
    align-items: start;
  }
  .metadata-item:hover {
    background-color: var(--color-gray-100);
    border-radius: var(--radius-sm);
    padding: var(--spacing-2);
    margin: calc(var(--spacing-2) * -1);
  }
  .dark .metadata-item:hover {
    background-color: var(--color-gray-700);
  }
  .metadata-icon {
    margin-right: var(--spacing-2);
    margin-top: 0.125rem;
  }
  .metadata-label {
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-700);
    display: block;
  }
  .dark .metadata-label {
    color: var(--color-gray-300);
  }
  .metadata-value {
    color: var(--color-gray-600);
  }
  .dark .metadata-value {
    color: var(--color-gray-400);
  }
  .gallery-navigation {
    margin-top: var(--spacing-8);
    padding-top: var(--spacing-6);
    border-top: 1px solid var(--color-gray-200);
  }
  .dark .gallery-navigation {
    border-top-color: var(--color-gray-700);
  }
  .gallery-stats {
    margin-bottom: var(--spacing-6);
    padding: var(--spacing-4);
    background-color: var(--color-gray-50);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-gray-200);
  }
  .dark .gallery-stats {
    background-color: var(--color-gray-800);
    border-color: var(--color-gray-700);
  }
  .gallery-empty-state {
    text-align: center;
    padding: var(--spacing-8) 0;
  }
  .gallery-empty-state svg {
    width: 4rem;
    height: 4rem;
    margin-left: auto;
    margin-right: auto;
    color: var(--color-gray-400);
    margin-bottom: var(--spacing-4);
  }
  .dark .gallery-empty-state svg {
    color: var(--color-gray-500);
  }
  .inline-gallery-compact .photo-grid {
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--spacing-2);
  }
  .inline-gallery-compact .photo-item-container {
    aspect-ratio: 1;
  }
  .gallery-header-section .gallery-title-main {
    margin-bottom: var(--spacing-2);
  }
  .gallery-header-section .gallery-description-text {
    margin-bottom: var(--spacing-4);
  }
  @media (max-width: 640px) {
    .metadata-grid {
      grid-template-columns: 1fr;
    }
    .photo-metadata-display {
      padding: 1rem;
    }
  }
}
@media print {
  .photo-gallery-wrapper {
    break-inside: avoid;
  }
  .photo-item-container {
    break-inside: avoid;
    margin-bottom: var(--spacing-4);
  }
  .photo-item-interactive::before {
    display: none;
  }
  .gallery-control-toggle-group {
    display: none;
  }
}
@layer components {
  .dashboard-action-card {
    display: flex;
    align-items: center;
    position: relative;
    padding: 0.75rem;
    border-radius: 0.5rem;
    background-color: transparent;
    border: 1px solid oklch(92.9% 0.013 255.508);
    transition-property: background-color, border-color, box-shadow;
    transition-duration: 200ms;
    cursor: pointer;
    text-decoration: none;
  }
  .dashboard-action-card:hover {
    background-color: oklch(98.4% 0.003 247.858);
    .dark & {
      background-color: oklch(27.9% 0.041 260.031);
    }
  }
  .dashboard-action-icon {
    margin-right: 0.75rem;
    font-size: 1.25rem;
    color: oklch(70.4% 0.04 256.788);
    transition: color 200ms;
    .dark & {
      color: oklch(55.4% 0.046 257.417);
    }
  }
  .dashboard-action-card:hover .dashboard-action-icon {
    color: oklch(44.6% 0.043 257.281);
    .dark & {
      color: oklch(86.9% 0.022 252.894);
    }
  }
  .dashboard-action-content {
    flex: 1;
    min-width: 0;
  }
  .dashboard-action-title {
    font-weight: 500;
    color: oklch(20.8% 0.042 265.755);
    margin-bottom: 0.25rem;
    .dark & {
      color: oklch(86.9% 0.022 252.894);
    }
  }
  .dashboard-action-description {
    font-size: 0.875rem;
    color: oklch(44.6% 0.043 257.281);
    .dark & {
      color: oklch(70.4% 0.04 256.788);
    }
  }
  .dashboard-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: 1fr;
    @media (min-width: 48rem) {
      grid-template-columns: repeat(2, 1fr);
    }
    @media (min-width: 64rem) {
      grid-template-columns: repeat(3, 1fr);
    }
  }
  .dashboard-section {
    overflow: hidden;
  }
  .dashboard-section-header {
    padding: 1rem;
    background-color: oklch(98.4% 0.003 247.858);
    border-bottom: 1px solid oklch(92.9% 0.013 255.508);
    .dark & {
      background-color: oklch(37.2% 0.044 257.287);
      border-color: oklch(44.6% 0.043 257.281);
    }
  }
  .dashboard-section-title {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  .dashboard-section-content {
    padding: 1rem;
  }
  .dashboard-stats-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  }
  .dashboard-stat-card {
    padding: 1rem;
    border-radius: 0.5rem;
    background-color: #fff;
    border: 1px solid oklch(92.9% 0.013 255.508);
    .dark & {
      background-color: oklch(27.9% 0.041 260.031);
      border-color: oklch(37.2% 0.044 257.287);
    }
  }
  .dashboard-stat-label {
    font-size: 0.875rem;
    color: oklch(44.6% 0.043 257.281);
    margin-bottom: 0.5rem;
    .dark & {
      color: oklch(70.4% 0.04 256.788);
    }
  }
  .dashboard-stat-value {
    font-size: 1.875rem;
    font-weight: 700;
    color: oklch(20.8% 0.042 265.755);
    line-height: 1;
    .dark & {
      color: oklch(96.8% 0.007 247.896);
    }
  }
  .dashboard-stat-trend {
    font-size: 0.875rem;
    margin-top: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
  }
  .dashboard-stat-trend-up {
    color: oklch(59.6% 0.145 163.225);
    .dark & {
      color: oklch(76.5% 0.177 163.223);
    }
  }
  .dashboard-stat-trend-down {
    color: oklch(58.6% 0.253 17.585);
    .dark & {
      color: oklch(71.2% 0.194 13.428);
    }
  }
}
@layer base {
  .dark {
    --token-brand-primary: oklch(68.5% 0.169 237.323);
    --token-brand-secondary: oklch(62.7% 0.265 303.9);
    --token-neutral-50: oklch(14.7% 0.004 49.25);
    --token-neutral-100: oklch(21.6% 0.006 56.043);
    --token-neutral-200: oklch(26.8% 0.007 34.298);
    --token-neutral-300: oklch(37.4% 0.01 67.558);
    --token-neutral-400: oklch(44.4% 0.011 73.639);
    --token-neutral-500: oklch(55.3% 0.013 58.071);
    --token-neutral-600: oklch(70.9% 0.01 56.259);
    --token-neutral-700: oklch(86.9% 0.005 56.366);
    --token-neutral-800: oklch(92.3% 0.003 48.717);
    --token-neutral-900: oklch(97% 0.001 106.424);
    --token-neutral-950: oklch(98.5% 0.001 106.423);
    --token-success-base: oklch(69.6% 0.17 162.48);
    --token-danger-base: oklch(63.7% 0.237 25.331);
    --token-warning-base: oklch(76.9% 0.188 70.08);
    --token-info-base: oklch(62.3% 0.214 259.815);
    --token-elevated-base: oklch(27.4% 0.006 286.033);
    --color-border-subtle: var(--token-neutral-300);
    --color-text-inverted-primary: var(--token-neutral-900);
    --color-text-inverted-secondary: var(--token-neutral-700);
    --color-text-inverted-tertiary: var(--token-neutral-600);
    --color-text-on-brand: var(--token-neutral-900);
    --color-text-on-light: var(--token-neutral-900);
    --token-shadow-subtle: 0 1px 3px 0 rgba(0, 0, 0, 0.3), 0 1px 2px 0 rgba(0, 0, 0, 0.2);
    --token-shadow-default: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
    --token-shadow-elevated: 0 10px 15px -3px rgba(0, 0, 0, 0.3), 0 4px 6px -2px rgba(0, 0, 0, 0.2);
    --token-shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.3), 0 10px 10px -5px rgba(0, 0, 0, 0.15);
    --token-shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, 0.4);
    --token-shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, 0.15);
    --token-shadow-inner-strong: inset 0 4px 8px 0 rgba(0, 0, 0, 0.25);
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateX(-20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes pulseBrand {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.7;
  }
}
@keyframes shimmer {
  0% {
    background-position: -200% 0;
  }
  100% {
    background-position: 200% 0;
  }
}
@media (prefers-contrast: high) {
  .text-high-contrast {
    color: color(from var(--color-text-primary) hsl h s calc(l > 50 ? 5: 95));
  }
  .border-high-contrast {
    border-color: color(from var(--color-border-default) hsl h s calc(l > 50 ? 20: 80));
  }
  .bg-high-contrast {
    background: color(from var(--color-background-primary) hsl h s calc(l > 50 ? 95: 5));
  }
}
@media print {
  .print-text-dark {
    color: #000000 !important;
  }
  .print-bg-light {
    background: #ffffff !important;
  }
  .print-border-dark {
    border-color: #000000 !important;
  }
}
@media (prefers-reduced-motion: reduce) {
  .hover-brand, .hover-subtle {
    transition: background-color 0ms, color 0ms, border-color 0ms, transform 0ms;
  }
}
@layer utilities {
  .bg-brand-gradient {
    background: linear-gradient( 135deg, var(--color-brand-primary, oklch(58.8% 0.158 241.966)) 0%, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 15) s calc(l + 10)) 50%, var(--color-brand-secondary, oklch(55.8% 0.288 302.321)) 100% );
  }
  .bg-brand-gradient-radial {
    background: radial-gradient( circle at center, var(--color-brand-primary, oklch(58.8% 0.158 241.966)) 0%, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 0.8) calc(l + 20)) 100% );
  }
  .bg-brand-gradient-conic {
    background: conic-gradient( from 0deg, var(--color-brand-primary, oklch(58.8% 0.158 241.966)) 0deg, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 120) s l) 120deg, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 240) s l) 240deg, var(--color-brand-primary, oklch(58.8% 0.158 241.966)) 360deg );
  }
  .bg-harmonic-analogous {
    background: linear-gradient( 90deg, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h - 30) s l) 0%, var(--color-brand-primary, oklch(58.8% 0.158 241.966)) 50%, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 30) s l) 100% );
  }
  .bg-harmonic-complementary {
    background: linear-gradient( 135deg, var(--color-brand-primary, oklch(58.8% 0.158 241.966)) 0%, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 180) s l) 100% );
  }
  .bg-harmonic-triadic {
    background: linear-gradient( 120deg, var(--color-brand-primary, oklch(58.8% 0.158 241.966)) 0%, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 120) s l) 50%, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 240) s l) 100% );
  }
  .bg-mono-light-to-dark {
    background: linear-gradient( 180deg, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l + 30)) 0%, var(--color-brand-primary, oklch(58.8% 0.158 241.966)) 50%, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l - 30)) 100% );
  }
  .bg-mono-saturated-to-muted {
    background: linear-gradient( 90deg, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 1.4) l) 0%, var(--color-brand-primary, oklch(58.8% 0.158 241.966)) 50%, color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 0.3) l) 100% );
  }
  .shadow-brand-soft {
    box-shadow: 0 4px 20px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.12);
  }
  .shadow-brand-medium {
    box-shadow: 0 8px 25px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.15);
  }
  .shadow-brand-sharp {
    box-shadow: 0 2px 8px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.25);
  }
  .shadow-brand-dramatic {
    box-shadow: 0 20px 50px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.18);
  }
  .shadow-success-soft {
    box-shadow: 0 4px 20px color(from var(--color-success, oklch(59.6% 0.145 163.225)) srgb r g b / 0.12);
  }
  .shadow-warning-soft {
    box-shadow: 0 4px 20px color(from var(--color-warning, oklch(76.9% 0.188 70.08)) srgb r g b / 0.12);
  }
  .shadow-danger-soft {
    box-shadow: 0 4px 20px color(from var(--color-danger, oklch(57.7% 0.245 27.325)) srgb r g b / 0.12);
  }
  .shadow-brand-inset {
    box-shadow: inset 0 2px 8px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.1);
  }
  .shadow-brand-inset-strong {
    box-shadow: inset 0 4px 12px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.2);
  }
  .shadow-brand-layered {
    box-shadow: 0 1px 3px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.12), 0 4px 12px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.08), 0 12px 24px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.04);
  }
  .bg-brand-whisper {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.03);
  }
  .bg-brand-ghost {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.08);
  }
  .bg-brand-subtle {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.15);
  }
  .bg-brand-overlay {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.25);
  }
  .bg-brand-backdrop {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.35);
  }
  .bg-success-whisper {
    background: color(from var(--color-success, oklch(59.6% 0.145 163.225)) srgb r g b / 0.03);
  }
  .bg-success-ghost {
    background: color(from var(--color-success, oklch(59.6% 0.145 163.225)) srgb r g b / 0.08);
  }
  .bg-warning-whisper {
    background: color(from var(--color-warning, oklch(76.9% 0.188 70.08)) srgb r g b / 0.03);
  }
  .bg-warning-ghost {
    background: color(from var(--color-warning, oklch(76.9% 0.188 70.08)) srgb r g b / 0.08);
  }
  .bg-danger-whisper {
    background: color(from var(--color-danger, oklch(57.7% 0.245 27.325)) srgb r g b / 0.03);
  }
  .bg-danger-ghost {
    background: color(from var(--color-danger, oklch(57.7% 0.245 27.325)) srgb r g b / 0.08);
  }
  .border-brand-light {
    border-color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l + 20));
  }
  .border-brand-muted {
    border-color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 0.6) l);
  }
  .border-brand-fade {
    border-color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.2);
  }
  .border-brand-ghost {
    border-color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.1);
  }
  .border-brand-gradient {
    border: 2px solid transparent;
    background: linear-gradient(var(--color-background-primary, #fff), var(--color-background-primary, #fff)) padding-box, linear-gradient(135deg, var(--color-brand-primary, oklch(58.8% 0.158 241.966)), color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 30) s l)) border-box;
  }
  .border-success-fade {
    border-color: color(from var(--color-success, oklch(59.6% 0.145 163.225)) srgb r g b / 0.2);
  }
  .border-warning-fade {
    border-color: color(from var(--color-warning, oklch(76.9% 0.188 70.08)) srgb r g b / 0.2);
  }
  .border-danger-fade {
    border-color: color(from var(--color-danger, oklch(57.7% 0.245 27.325)) srgb r g b / 0.2);
  }
  .text-brand-muted {
    color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 0.8) calc(l - 10));
  }
  .text-brand-vibrant {
    color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 1.3) calc(l - 5));
  }
  .text-brand-light {
    color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l + 20));
  }
  .text-brand-dark {
    color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l - 20));
  }
  .text-auto-contrast-light {
    color: color(from var(--color-background-primary, #fff) hsl h s calc(l > 50 ? 15 : 85));
  }
  .text-auto-contrast-brand {
    color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l > 50 ? 15 : 85));
  }
  .bg-brand-analogous-warm {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 30) calc(s * 0.8) calc(l + 30));
  }
  .bg-brand-analogous-cool {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h - 30) calc(s * 0.8) calc(l + 30));
  }
  .bg-brand-complementary-soft {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 180) calc(s * 0.3) calc(l + 35));
  }
  .bg-brand-triadic-soft {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 120) calc(s * 0.3) calc(l + 35));
  }
  .bg-brand-tinted {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 0.2) calc(l + 40));
  }
  .bg-success-tinted {
    background: color(from var(--color-success, oklch(59.6% 0.145 163.225)) hsl h calc(s * 0.2) calc(l + 40));
  }
  .bg-warning-tinted {
    background: color(from var(--color-warning, oklch(76.9% 0.188 70.08)) hsl h calc(s * 0.2) calc(l + 40));
  }
  .bg-danger-tinted {
    background: color(from var(--color-danger, oklch(57.7% 0.245 27.325)) hsl h calc(s * 0.2) calc(l + 40));
  }
  .hover-brand-lift:hover {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 1.1) calc(l - 8));
    transform: translateY(-2px);
    box-shadow: 0 8px 25px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.15);
  }
  .hover-brand-glow:hover {
    box-shadow: 0 0 20px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.3);
  }
  .hover-brand-darken:hover {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l - 12));
  }
  .hover-brand-lighten:hover {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l + 12));
  }
  .hover-brand-saturate:hover {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 1.2) l);
  }
  .hover-brand-desaturate:hover {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 0.7) l);
  }
  .focus-brand-ring:focus {
    outline: 2px solid color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.5);
    outline-offset: 2px;
  }
  .focus-brand-complementary:focus {
    outline: 2px solid color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl calc(h + 180) s l);
    outline-offset: 2px;
  }
  .focus-brand-contrast:focus {
    outline: 2px solid color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l > 50 ? 15 : 85));
    outline-offset: 2px;
  }
  .transition-colors-smooth {
    transition: background-color 300ms cubic-bezier(0.4, 0, 0.2, 1), color 300ms cubic-bezier(0.4, 0, 0.2, 1), border-color 300ms cubic-bezier(0.4, 0, 0.2, 1);
  }
  .transition-colors-quick {
    transition: background-color 150ms ease-out, color 150ms ease-out, border-color 150ms ease-out;
  }
  .transition-colors-slow {
    transition: background-color 500ms ease-in-out, color 500ms ease-in-out, border-color 500ms ease-in-out;
  }
  .text-high-contrast {
    color: color(from var(--color-text-primary, oklch(20.8% 0.042 265.755)) hsl h s calc(l > 50 ? 5 : 95));
  }
  .border-high-contrast {
    border-color: color(from var(--color-border-default, oklch(86.9% 0.022 252.894)) hsl h s calc(l > 50 ? 20 : 80));
  }
  .bg-high-contrast {
    background: color(from var(--color-background-primary, #fff) hsl h s calc(l > 50 ? 5 : 95));
    color: color(from var(--color-background-primary, #fff) hsl h s calc(l > 50 ? 95 : 5));
  }
  .text-wcag-aa {
    color: color(from var(--color-background-primary, #fff) hsl h s calc(l > 50 ? 20 : 80));
  }
  .text-wcag-aaa {
    color: color(from var(--color-background-primary, #fff) hsl h s calc(l > 50 ? 15 : 85));
  }
  .dark .bg-brand-dark-enhanced {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 0.9) calc(l + 20));
  }
  .dark .text-brand-dark-enhanced {
    color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 1.1) calc(l + 25));
  }
  .dark .shadow-brand-dark-enhanced {
    box-shadow: 0 8px 25px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.25);
  }
  @media print {
    .print-brand-text {
      color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s 20) !important;
    }
    .print-remove-bg {
      background: transparent !important;
    }
    .print-border-dark {
      border-color: #000 !important;
    }
  }
  .brand-card {
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.05);
    border: 1px solid color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.2);
    color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h calc(s * 1.1) calc(l - 10));
  }
  .brand-button {
    background: var(--color-brand-primary, oklch(58.8% 0.158 241.966));
    color: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l > 50 ? 15 : 85));
    border: 1px solid color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) hsl h s calc(l - 10));
  }
  .brand-input {
    border: 1px solid color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.3);
    background: color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.02);
  }
  .brand-input:focus {
    border-color: var(--color-brand-primary, oklch(58.8% 0.158 241.966));
    box-shadow: 0 0 0 3px color(from var(--color-brand-primary, oklch(58.8% 0.158 241.966)) srgb r g b / 0.15);
  }
  .context-light {
    --local-bg: #fff;
    --local-text: color(from var(--local-bg) hsl h s 15);
    --local-border: color(from var(--local-bg) hsl h s 85);
    background: var(--local-bg);
    color: var(--local-text);
    border-color: var(--local-border);
  }
  .context-dark {
    --local-bg: oklch(20.8% 0.042 265.755);
    --local-text: color(from var(--local-bg) hsl h s 85);
    --local-border: color(from var(--local-bg) hsl h s 15);
    background: var(--local-bg);
    color: var(--local-text);
    border-color: var(--local-border);
  }
  .context-brand {
    --local-bg: var(--color-brand-primary, oklch(58.8% 0.158 241.966));
    --local-text: color(from var(--local-bg) hsl h s calc(l > 50 ? 15 : 85));
    --local-border: color(from var(--local-bg) hsl h s calc(l - 15));
    background: var(--local-bg);
    color: var(--local-text);
    border-color: var(--local-border);
  }
}
@layer utilities {
  @media (prefers-contrast: high) {
    .text-high-contrast {
      color: color(from var(--color-text-primary) hsl h s calc(l > 50 ? 5: 95));
    }
    .bg-high-contrast {
      background: color( from var(--color-background-primary) hsl h s calc(l > 50 ? 95: 5) );
    }
    .border-high-contrast {
      border-color: color( from var(--color-border-default) hsl h s calc(l > 50 ? 20: 80) );
      border-width: 2px;
    }
    .btn-high-contrast {
      border-width: 3px;
      font-weight: 700;
      background: color( from var(--color-brand-primary) hsl h calc(max(80, s)) calc(l > 50 ? 20: 80) );
      color: color( from var(--color-brand-primary) hsl h s calc(l > 50 ? 95: 5) );
      &:hover {
        background: color( from var(--color-brand-primary) hsl h calc(max(90, s)) calc(l > 50 ? 15: 85) );
      }
    }
    .input-high-contrast {
      border-width: 3px;
      border-color: color( from var(--color-border-default) hsl h s calc(l > 50 ? 30: 70) );
      &:focus {
        border-width: 3px;
        box-shadow: 0 0 0 2px var(--color-background-primary), 0 0 0 5px var(--color-brand-primary);
      }
    }
    .link-high-contrast {
      color: color( from var(--color-brand-primary) hsl h calc(max(80, s)) calc(l > 50 ? 25: 75) );
      text-decoration: underline;
      text-decoration-thickness: 2px;
      &:hover {
        text-decoration-thickness: 3px;
        background: color(from var(--color-brand-primary) srgb r g b / 0.2);
      }
    }
  }
}
@layer utilities {
  @media (prefers-color-scheme: dark) and (prefers-contrast: more) {
    .text-ambient-auto {
      color: color( from var(--color-text-primary) hsl h s calc(min(95, l + 15)) );
    }
    .bg-ambient-auto {
      background: color( from var(--color-background-primary) hsl h s calc(max(5, l - 15)) );
    }
  }
  @media (prefers-color-scheme: light) and (prefers-contrast: more) {
    .text-ambient-auto {
      color: color( from var(--color-text-primary) hsl h s calc(max(5, l - 15)) );
    }
    .bg-ambient-auto {
      background: color( from var(--color-background-primary) hsl h s calc(min(95, l + 15)) );
    }
  }
}
@layer utilities {
  @media print {
    .print-contrast {
      color: #000000 !important;
      background: #ffffff !important;
      border-color: #000000 !important;
      text-shadow: none !important;
      box-shadow: none !important;
    }
    .print-contrast-borders {
      border: 1px solid #000000 !important;
    }
    .print-high-contrast {
      color: #000000 !important;
      background: #ffffff !important;
      border: 2px solid #000000 !important;
      font-weight: 600 !important;
    }
  }
}
@layer utilities {
  @media (forced-colors: active) {
    .forced-colors-text {
      color: CanvasText !important;
    }
    .forced-colors-bg {
      background: Canvas !important;
    }
    .forced-colors-border {
      border-color: ButtonBorder !important;
    }
    .forced-colors-link {
      color: LinkText !important;
      &:visited {
        color: VisitedText !important;
      }
    }
    .forced-colors-button {
      color: ButtonText !important;
      background: ButtonFace !important;
      border-color: ButtonBorder !important;
      &:hover {
        background: Highlight !important;
        color: HighlightText !important;
      }
    }
  }
}
@layer utilities {
  @media (prefers-reduced-transparency: reduce) {
    .reduced-transparency {
      background: var(--color-background-primary) !important;
      backdrop-filter: none !important;
    }
    .reduced-transparency-overlay {
      background: var(--color-background-primary) !important;
      opacity: 1 !important;
    }
  }
}
@media (prefers-reduced-data: no-preference) {
  .color-test-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    padding: 1rem;
    margin: 2rem 0;
  }
  .color-test-swatch {
    --test-color: var(--color-brand-primary);
    height: 120px;
    border-radius: var(--radius-md);
    border: 2px solid var(--color-border-default);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.875rem;
    font-weight: 600;
    text-align: center;
    padding: 1rem;
    transition: transform 150ms ease;
    &:hover {
      transform: scale(1.05);
      border-color: var(--color-brand-primary);
    }
    &::after {
      content: attr(data-color-info);
      position: absolute;
      bottom: 0.5rem;
      left: 0.5rem;
      right: 0.5rem;
      background: rgba(0, 0, 0, 0.8);
      color: white;
      padding: 0.25rem 0.5rem;
      border-radius: 4px;
      font-size: 0.75rem;
      font-family: monospace;
      line-height: 1.2;
      opacity: 0;
      transition: opacity 150ms ease;
    }
    &:hover::after {
      opacity: 1;
    }
  }
  .color-test-swatch[data-variant="original"] {
    background: var(--test-color);
    color: color(from var(--test-color) hsl h s calc(l > 60 ? 15: 85));
  }
  .color-test-swatch[data-variant="lighter"] {
    background: color(from var(--test-color) hsl h s calc(l + 20));
    color: color(from var(--test-color) hsl h s calc(l + 20 > 60 ? 15: 85));
  }
  .color-test-swatch[data-variant="darker"] {
    background: color(from var(--test-color) hsl h s calc(l - 20));
    color: color(from var(--test-color) hsl h s calc(l - 20 > 60 ? 15: 85));
  }
  .color-test-swatch[data-variant="muted"] {
    background: color(from var(--test-color) hsl h calc(s * 0.6) l);
    color: color(from var(--test-color) hsl h calc(s * 0.6) calc(l > 60 ? 15: 85));
  }
  .color-test-swatch[data-variant="vibrant"] {
    background: color(from var(--test-color) hsl h calc(s * 1.3) l);
    color: color(from var(--test-color) hsl h calc(s * 1.3) calc(l > 60 ? 15: 85));
  }
  .color-test-swatch[data-variant="ghost"] {
    background: color(from var(--test-color) srgb r g b / 0.1);
    color: var(--test-color);
  }
  .color-test-swatch[data-variant="complementary"] {
    background: color(from var(--test-color) hsl calc(h + 180) s l);
    color: color(from var(--test-color) hsl calc(h + 180) s calc(l > 60 ? 15: 85));
  }
  .color-test-swatch[data-variant="analogous-warm"] {
    background: color(from var(--test-color) hsl calc(h + 30) s l);
    color: color(from var(--test-color) hsl calc(h + 30) s calc(l > 60 ? 15: 85));
  }
  .color-test-swatch[data-variant="analogous-cool"] {
    background: color(from var(--test-color) hsl calc(h - 30) s l);
    color: color(from var(--test-color) hsl calc(h - 30) s calc(l > 60 ? 15: 85));
  }
  .color-test-swatch[data-variant="triadic-1"] {
    background: color(from var(--test-color) hsl calc(h + 120) s l);
    color: color(from var(--test-color) hsl calc(h + 120) s calc(l > 60 ? 15: 85));
  }
  .color-test-swatch[data-variant="triadic-2"] {
    background: color(from var(--test-color) hsl calc(h + 240) s l);
    color: color(from var(--test-color) hsl calc(h + 240) s calc(l > 60 ? 15: 85));
  }
  .contrast-test-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1rem;
    margin: 2rem 0;
  }
  .contrast-test-item {
    padding: 2rem;
    border-radius: var(--radius-md);
    border: 2px solid var(--color-border-default);
    position: relative;
    &::before {
      content: "Contrast: " attr(data-contrast-ratio);
      position: absolute;
      top: 0.5rem;
      right: 0.5rem;
      background: rgba(0, 0, 0, 0.8);
      color: white;
      padding: 0.25rem 0.5rem;
      border-radius: 4px;
      font-size: 0.75rem;
      font-family: monospace;
    }
    &[data-contrast-status="fail"] {
      border-color: var(--color-danger);
      &::before {
        background: var(--color-danger);
        color: white;
      }
    }
    &[data-contrast-status="aa"] {
      border-color: var(--color-warning);
      &::before {
        background: var(--color-warning);
        color: var(--color-text-on-warning);
      }
    }
    &[data-contrast-status="aaa"] {
      border-color: var(--color-success);
      &::before {
        background: var(--color-success);
        color: white;
      }
    }
  }
  .contrast-test-text {
    margin: 0.5rem 0;
    &.large-text {
      font-size: 1.125rem;
      font-weight: 600;
    }
    &.normal-text {
      font-size: 1rem;
      font-weight: 400;
    }
    &.small-text {
      font-size: 0.875rem;
      font-weight: 400;
    }
  }
  .browser-support-test {
    padding: 2rem;
    margin: 2rem 0;
    border: 2px dashed var(--color-border-default);
    border-radius: var(--radius-lg);
    text-align: center;
    background: var(--color-brand-primary);
    color: white;
    background: color(from var(--color-brand-primary) hsl h s calc(l - 10));
    color: color(from var(--color-brand-primary) hsl h s calc(l > 60 ? 15: 85));
  }
  .browser-support-indicator {
    display: inline-block;
    padding: 0.5rem 1rem;
    border-radius: var(--radius-sm);
    font-weight: 600;
    margin: 0.25rem;
    background: var(--color-danger);
    color: white;
    &::before {
      content: "❌ Not Supported";
    }
    background: color(from var(--color-success) hsl h s l);
    color: color(from var(--color-success) hsl h s calc(l > 60 ? 15: 85));
    &::before {
      content: "✅ Supported";
    }
  }
  .color-space-test {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
    margin: 2rem 0;
  }
  .color-space-swatch {
    height: 100px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 600;
    color: white;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
    &[data-space="srgb"] {
      background: color(from var(--color-brand-primary) srgb r g b);
    }
    &[data-space="hsl"] {
      background: color(from var(--color-brand-primary) hsl h s l);
    }
    &[data-space="hwb"] {
      background: color(from var(--color-brand-primary) hwb h w b);
    }
    &[data-space="lch"] {
      background: color(from var(--color-brand-primary) lch l c h);
    }
    &[data-space="oklch"] {
      background: color(from var(--color-brand-primary) oklch l c h);
    }
  }
  .animation-test {
    padding: 2rem;
    margin: 2rem 0;
    border-radius: var(--radius-lg);
    background: var(--color-brand-primary);
    color: var(--color-text-on-brand);
    animation: color-cycle 4s infinite;
  }
  @keyframes color-cycle {
    0% {
      background: color(from var(--color-brand-primary) hsl h s l);
    }
    25% {
      background: color(from var(--color-brand-primary) hsl calc(h + 90) s l);
    }
    50% {
      background: color(from var(--color-brand-primary) hsl calc(h + 180) s l);
    }
    75% {
      background: color(from var(--color-brand-primary) hsl calc(h + 270) s l);
    }
    100% {
      background: color(from var(--color-brand-primary) hsl h s l);
    }
  }
  .gradient-test-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1rem;
    margin: 2rem 0;
  }
  .gradient-test-swatch {
    height: 120px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    color: white;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
    &[data-gradient="linear"] {
      background: linear-gradient( 135deg, var(--color-brand-primary), color(from var(--color-brand-primary) hsl calc(h + 60) s l) );
    }
    &[data-gradient="radial"] {
      background: radial-gradient( circle, color(from var(--color-brand-primary) hsl h s calc(l + 20)), color(from var(--color-brand-primary) hsl h s calc(l - 20)) );
    }
    &[data-gradient="conic"] {
      background: conic-gradient( from 0deg, var(--color-brand-primary), color(from var(--color-brand-primary) hsl calc(h + 120) s l), color(from var(--color-brand-primary) hsl calc(h + 240) s l), var(--color-brand-primary) );
    }
  }
  .debug-color-info {
    position: fixed;
    top: 1rem;
    right: 1rem;
    background: rgba(0, 0, 0, 0.9);
    color: white;
    padding: 1rem;
    border-radius: var(--radius-md);
    font-family: monospace;
    font-size: 0.75rem;
    line-height: 1.4;
    z-index: 9999;
    max-width: 300px;
    display: none;
    &.active {
      display: block;
    }
  }
  .debug-color-picker {
    margin: 1rem 0;
    input[type="color"] {
      width: 50px;
      height: 50px;
      border: none;
      border-radius: var(--radius-sm);
      cursor: pointer;
    }
    input[type="range"] {
      width: 200px;
      margin: 0.5rem;
    }
  }
  .color-syntax-error {
    background: var(--color-danger) !important;
    color: white !important;
    border: 2px solid var(--color-danger) !important;
    &::before {
      content: "⚠ Relative colour syntax not supported";
      display: block;
      font-weight: 600;
      margin-bottom: 0.5rem;
    }
  }
  @media print {
    .dev-testing-only {
      display: none !important;
    }
    .color-test-grid, .contrast-test-container, .browser-support-test, .animation-test {
      display: none !important;
    }
  }
  .sr-test {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
    &:focus {
      position: static;
      width: auto;
      height: auto;
      padding: 0.5rem;
      margin: 0;
      overflow: visible;
      clip: auto;
      white-space: normal;
      background: var(--color-brand-primary);
      color: var(--color-text-on-brand);
      border-radius: var(--radius-sm);
    }
  }
  @media (prefers-reduced-motion: reduce) {
    .animation-test {
      animation: none;
      background: var(--color-brand-primary) !important;
    }
    .animation-test::after {
      content: "✅ Reduced motion respected";
      display: block;
      margin-top: 1rem;
      padding: 0.5rem;
      background: var(--color-success);
      color: white;
      border-radius: var(--radius-sm);
      font-weight: 600;
    }
  }
  @media (prefers-contrast: high) {
    .contrast-test-item {
      border-width: 3px;
    }
    .high-contrast-indicator {
      display: block !important;
      background: var(--color-success);
      color: white;
      padding: 0.5rem;
      border-radius: var(--radius-sm);
      font-weight: 600;
      text-align: center;
      margin: 1rem 0;
      &::before {
        content: "✅ High contrast mode active";
      }
    }
  }
  .high-contrast-indicator {
    display: none;
  }
}
@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-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-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-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-tracking {
  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-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;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
@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-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-font-weight: initial;
      --tw-tracking: 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-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;
      --tw-leading: initial;
    }
  }
}
