@charset "UTF-8";
:root {
  /* ── Base colors ──────────────────────────────────────── */
  --base-primary: #8600a7;
  --base-secondary: #ff757d;
  --base-tertiary: #1ec8a5;
  --base-success: #198754;
  --base-info: #0dcaf0;
  --base-warning: #ffc107;
  --base-danger: #dc3545;
  /* ── Surface colors ───────────────────────────────────── */
  --surface-primary-bg: color-mix(in srgb, var(--body-bg) 98%, var(--body-color));
  --surface-primary-color: color(from var(--body-color) srgb r g b / 0.75);
  --surface-secondary-bg: color-mix(in srgb, var(--body-bg) 94%, var(--body-color));
  --surface-secondary-color: color(from var(--body-color) srgb r g b / 0.5);
  /* ── Semantic color tokens ────────────────────────────── */
  --primary-bg: var(--base-primary);
  --primary-color: var(--base-primary); /*oklch(from var(--base-primary) calc(l - 0.2) c h);*/
  --secondary-bg: var(--base-secondary);
  --secondary-color: var(--base-secondary); /*oklch(from var(--base-secondary) calc(l - 0.2) c h);*/
  --tertiary-bg: var(--base-tertiary);
  --tertiary-color: var(--base-tertiary); /*oklch(from var(--base-tertiary) calc(l - 0.2) c h);*/
  --success-bg: var(--base-success);
  --success-color: var(--base-success); /*oklch(from var(--base-success) calc(l - 0.2) c h);*/
  --info-bg: var(--base-info);
  --info-color: var(--base-info); /*oklch(from var(--base-info) calc(l - 0.2) c h);*/
  --warning-bg: var(--base-warning);
  --warning-color: var(--base-warning); /*oklch(from var(--base-warning) calc(l - 0.2) c h);*/
  --danger-bg: var(--base-danger);
  --danger-color: var(--base-danger); /*oklch(from var(--base-danger) calc(l - 0.2) c h);*/
  /* ── Layout (JS-readable) ─────────────────────────────── */
  --layout-header-height: 0px;
  --layout-navbar-height: 0px;
  /* ── Direction ────────────────────────────────────────── */
  --dir: 1;
  /* ── Breakpoints (JS-readable) ────────────────────────── */
  --breakpoint-tablet: 37.5rem;
  --breakpoint-laptop: 77.5rem;
  --breakpoint-desktop: 90rem;
  --breakpoint-wall: 120rem;
  --breakpoint-ultra: 160rem;
  /* ── Spacing ──────────────────────────────────────────── */
  --scale: 0.85;
  --scale: clamp( 0.85, calc(0.85 + (1 - 0.85) * ((100vw - 768px) / (2560px - 768px))), 1 );
  --space-base: calc(0.5rem * var(--scale));
  --space-1: calc(var(--space-base) * 0.5);
  --space-2: calc(var(--space-base) * 1);
  --space-3: calc(var(--space-base) * 2);
  --space-4: calc(var(--space-base) * 4);
  --space-5: calc(var(--space-base) * 8);
  /* ── Typography ───────────────────────────────────────── */
  --font-base: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Oxygen, Ubuntu, Cantarell, Open Sans, Helvetica Neue, sans-serif;
  --font-code: SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
  /* ── Elevation ────────────────────────────────────────── */
  --elevation-size-1: 0;
  --elevation-size-2: 0;
  --elevation-size-3: 0;
  --elevation-mix: 0;
  --elevation-mix-1: 0;
  --elevation-mix-2: 0;
  --elevation-mix-3: 0;
  --animation-duration: 0.25s;
  --animation-ease: ease;
  --border-width: 1px;
  --border-radius: 0;
}
.skin-body, .tone-body, .emboss-body {
  color: var(--body-color);
  background-color: var(--body-bg);
}
.skin-surface-primary, .tone-surface-primary, .emboss-surface-primary {
  color: var(--surface-primary-color);
  background-color: var(--surface-primary-bg);
}
.skin-surface-secondary, .tone-surface-secondary, .emboss-surface-secondary {
  color: var(--surface-secondary-color);
  background-color: var(--surface-secondary-bg);
}
.skin-primary, .tone-primary, .emboss-primary {
  color: var(--body-bg);
  background-color: var(--primary-bg);
}
.skin-secondary, .tone-secondary, .emboss-secondary {
  color: var(--body-bg);
  background-color: var(--secondary-bg);
}
.skin-tertiary, .tone-tertiary, .emboss-tertiary {
  color: var(--body-bg);
  background-color: var(--tertiary-bg);
}
.skin-success, .tone-success, .emboss-success {
  color: var(--body-bg);
  background-color: var(--success-bg);
}
.skin-info, .tone-info, .emboss-info {
  color: var(--body-bg);
  background-color: var(--info-bg);
}
.skin-warning, .tone-warning, .emboss-warning {
  color: var(--body-bg);
  background-color: var(--warning-bg);
}
.skin-danger, .tone-danger, .emboss-danger {
  color: var(--body-bg);
  background-color: var(--danger-bg);
}
.tone-body, .emboss-body {
  border: solid var(--body-color) var(--border-width);
  border-radius: var(--border-radius);
}
.tone-surface-primary, .emboss-surface-primary {
  border: solid var(--surface-primary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.tone-surface-secondary, .emboss-surface-secondary {
  border: solid var(--surface-secondary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.tone-primary, .emboss-primary {
  border: solid var(--primary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.tone-secondary, .emboss-secondary {
  border: solid var(--secondary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.tone-tertiary, .emboss-tertiary {
  border: solid var(--tertiary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.tone-success, .emboss-success {
  border: solid var(--success-color) var(--border-width);
  border-radius: var(--border-radius);
}
.tone-info, .emboss-info {
  border: solid var(--info-color) var(--border-width);
  border-radius: var(--border-radius);
}
.tone-warning, .emboss-warning {
  border: solid var(--warning-color) var(--border-width);
  border-radius: var(--border-radius);
}
.tone-danger, .emboss-danger {
  border: solid var(--danger-color) var(--border-width);
  border-radius: var(--border-radius);
}
.emboss-body {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.emboss-surface-primary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.emboss-surface-secondary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.emboss-primary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.emboss-secondary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.emboss-tertiary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.emboss-success {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.emboss-info {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.emboss-warning {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.emboss-danger {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.skin-bg-gradient {
  background-image: linear-gradient(180deg, color-mix(in srgb, var(--body-color) 15%, transparent), transparent);
}
[dir=rtl] {
  --dir: -1;
}
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html,
body {
  min-height: 100dvh;
}
body {
  font-family: var(--font-base);
  color: var(--body-color);
  background: var(--body-bg);
}
address, .address {
  margin-block-end: var(--space-3);
  font-style: normal;
  line-height: inherit;
}
address strong, address a, address span, .address strong, .address a, .address span {
  display: flow;
}
/* ================================================================
   ANIMATION ATOM
   Centralized motion patterns for the Neo framework.

   Roles:
   1. Fade/Slide  - entry + exit via @starting-style + allow-discrete
   2. Enter       - entry-only keyframe (for responsive elements)
   3. Collapse    - grid-row expand/contract (accordions)
   4. Spin        - continuous rotation (loaders, spinners)
   5. Transition  - shorthand helper for hover/interaction transitions

   Entry+exit (fade/slide) uses @starting-style so display:none is
   kept for hiding. Use ONLY on non-responsive overlays (drawers,
   backdrop, goTop). Responsive elements that change behavior on
   resize must use the enter-* keyframe mixins to avoid animating
   on breakpoint changes.

   RTL: inline-start/end use var(--dir) from _tokens.scss.
   ================================================================ */
/* ── 1. Fade (entry + exit) ───────────────────────────────── */
/* ── 1b. Slide (entry + exit) ─────────────────────────────── */
/* ── 2. Entry-only (keyframe, safe for responsive elements) ── */
@keyframes neo-fade-in {
  from {
    opacity: 0;
  }
}
@keyframes neo-slide-up {
  from {
    translate: 0 var(--_enter-distance);
  }
}
@keyframes neo-slide-down {
  from {
    translate: 0 calc(var(--_enter-distance) * -1);
  }
}
@keyframes neo-slide-inline-start {
  from {
    translate: calc(var(--dir) * var(--_enter-distance) * -1) 0;
  }
}
@keyframes neo-slide-inline-end {
  from {
    translate: calc(var(--dir) * var(--_enter-distance)) 0;
  }
}
/* ── 3. Collapse: inline expand/contract (accordion, expander) ── */
/* ── 4. Spin: continuous rotation ─────────────────────────── */
@keyframes neo-spin {
  to {
    rotate: 360deg;
  }
}
/* ── 5. Neo glass: frosted glass surface effect ──────────── */
/* ── 6. Transition: shorthand helper ──────────────────────── */
/* ================================================================
   SELECTORS
   ================================================================ */
/* ── Fade (entry + exit) ─────────────────────────────────── */
.fade {
  display: none;
  opacity: 0;
  transition: opacity var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
.fade-in {
  display: block;
  opacity: 1;
}
@starting-style {
  .fade-in {
    opacity: 0;
  }
}
/* ── Slide (entry + exit) ────────────────────────────────── */
.slide-up {
  --_slide-x: 0;
  --_slide-y: 0.625rem;
  display: none;
  translate: var(--_slide-x) var(--_slide-y);
  transition: translate var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
.slide-down {
  --_slide-x: 0;
  --_slide-y: calc(0.625rem * -1);
  display: none;
  translate: var(--_slide-x) var(--_slide-y);
  transition: translate var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
.slide-inline-start {
  --_slide-x: calc(var(--dir) * 100% * -1);
  --_slide-y: 0;
  display: none;
  translate: var(--_slide-x) var(--_slide-y);
  transition: translate var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
.slide-inline-end {
  --_slide-x: calc(var(--dir) * 100%);
  --_slide-y: 0;
  display: none;
  translate: var(--_slide-x) var(--_slide-y);
  transition: translate var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
.slide-in {
  display: block;
  translate: 0 0;
}
@starting-style {
  .slide-in {
    translate: var(--_slide-x) var(--_slide-y);
  }
}
/* ── Entry-only (keyframe) ───────────────────────────────── */
.enter-fade-in {
  animation: neo-fade-in var(--animation-duration) var(--animation-ease);
}
.enter-slide-up {
  --_enter-distance: 0.625rem;
  animation: neo-slide-up var(--animation-duration) var(--animation-ease);
}
.enter-slide-down {
  --_enter-distance: 0.625rem;
  animation: neo-slide-down var(--animation-duration) var(--animation-ease);
}
.enter-slide-inline-start {
  --_enter-distance: 0.625rem;
  animation: neo-slide-inline-start var(--animation-duration) var(--animation-ease);
}
.enter-slide-inline-end {
  --_enter-distance: 0.625rem;
  animation: neo-slide-inline-end var(--animation-duration) var(--animation-ease);
}
/* ── Collapse ────────────────────────────────────────────── */
.collapse {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--animation-duration) var(--animation-ease);
}
.collapse > * {
  overflow: hidden;
  min-block-size: 0;
}
.collapse-open {
  grid-template-rows: 1fr;
}
/* ── Neo glass ───────────────────────────────────────────── */
.neo-glass {
  background: color(from var(--body-color) srgb r g b/0.03);
  backdrop-filter: var(--neo-blur) saturate(140%);
}
.backdrop {
  position: fixed;
  inset: 0;
  z-index: 425;
  background: color(from var(--body-color) srgb r g b/0.5);
  display: none;
  opacity: 0;
  transition: opacity var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
.backdrop:not([aria-hidden=true]) {
  display: block;
  opacity: 1;
}
@starting-style {
  .backdrop:not([aria-hidden=true]) {
    opacity: 0;
  }
}
html:has(.backdrop:not([aria-hidden=true])) body {
  position: fixed;
  inset-inline: 0;
  width: 100%;
  overflow: hidden;
}
/* Neo surface: frosted glass effect */
.border-body {
  border: solid var(--body-color) var(--border-width);
  border-radius: var(--border-radius);
}
.border-surface-primary {
  border: solid var(--surface-primary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.border-surface-secondary {
  border: solid var(--surface-secondary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.border-primary {
  border: solid var(--primary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.border-secondary {
  border: solid var(--secondary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.border-tertiary {
  border: solid var(--tertiary-color) var(--border-width);
  border-radius: var(--border-radius);
}
.border-success {
  border: solid var(--success-color) var(--border-width);
  border-radius: var(--border-radius);
}
.border-info {
  border: solid var(--info-color) var(--border-width);
  border-radius: var(--border-radius);
}
.border-warning {
  border: solid var(--warning-color) var(--border-width);
  border-radius: var(--border-radius);
}
.border-danger {
  border: solid var(--danger-color) var(--border-width);
  border-radius: var(--border-radius);
}
.chevron {
  flex-shrink: 0;
  inline-size: 1.25rem;
  block-size: 1.25rem;
  transition: rotate var(--animation-duration) var(--animation-ease);
}
[aria-expanded=true] > .chevron {
  rotate: 180deg;
}
.cursor-auto {
  cursor: auto;
}
.cursor-default {
  cursor: default;
}
.cursor-pointer {
  cursor: pointer;
}
.cursor-wait {
  cursor: wait;
}
.cursor-text {
  cursor: text;
}
.cursor-move {
  cursor: move;
}
.cursor-help {
  cursor: help;
}
.cursor-not-allowed {
  cursor: not-allowed;
}
.cursor-zoom-in {
  cursor: zoom-in;
}
.cursor-zoom-out {
  cursor: zoom-out;
}
.cursor-grab {
  cursor: grab;
}
.cursor-grabbing {
  cursor: grabbing;
}
.block {
  display: block;
}
.flex {
  display: flex;
}
.grid {
  display: grid;
}
.inline-block {
  display: inline-block;
}
.inline {
  display: inline;
}
.inline-flex {
  display: inline-flex;
}
.inline-grid {
  display: inline-grid;
}
.table {
  display: table;
}
.table-row {
  display: table-row;
}
.table-cell {
  display: table-cell;
}
.elevation-body-1, .elevation-surface-primary-1, .elevation-surface-secondary-1, .elevation-primary-1, .elevation-secondary-1, .elevation-tertiary-1, .elevation-success-1, .elevation-info-1, .elevation-warning-1, .elevation-danger-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix), transparent);
}
.elevation-body-2, .elevation-surface-primary-2, .elevation-surface-secondary-2, .elevation-primary-2, .elevation-secondary-2, .elevation-tertiary-2, .elevation-success-2, .elevation-info-2, .elevation-warning-2, .elevation-danger-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix), transparent);
}
.elevation-body-3, .elevation-surface-primary-3, .elevation-surface-secondary-3, .elevation-primary-3, .elevation-secondary-3, .elevation-tertiary-3, .elevation-success-3, .elevation-info-3, .elevation-warning-3, .elevation-danger-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--body-color) var(--elevation-mix), transparent);
}
.float-start {
  float: inline-start;
}
.float-end {
  float: inline-end;
}
:focus-visible {
  outline: var(--border-width) solid currentcolor;
  outline-offset: var(--space-1);
  box-shadow: none;
}
h1, h2, h3, h4, h5, h6 {
  color: inherit;
  line-height: 1.35;
}
h1 {
  font-size: clamp(2.25rem, 4vw + 1rem, 3.5rem);
  font-weight: 400;
  letter-spacing: -0.015em;
}
h2 {
  font-size: clamp(2rem, 3vw + 1rem, 3rem);
  font-weight: 400;
  letter-spacing: -0.01em;
}
h3 {
  font-size: clamp(1.75rem, 2.5vw + 1rem, 2.5rem);
  font-weight: 400;
  letter-spacing: 0;
}
h4 {
  font-size: clamp(1.5rem, 2vw + 1rem, 2rem);
  font-weight: 500;
  letter-spacing: 0.0075em;
}
h5 {
  font-size: clamp(1.125rem, 1.5vw + 1rem, 1.5rem);
  font-weight: 500;
  letter-spacing: 0.0075em;
}
h6 {
  font-size: clamp(1rem, 1.2vw + 1rem, 1.125rem);
  font-weight: 500;
  letter-spacing: 0.01em;
}
html:has(.loader:not([aria-hidden=true])),
html:has(.loader:not([aria-hidden=true])) body {
  overflow: hidden;
}
.loader {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--body-bg);
  overflow: hidden;
  transition: opacity var(--animation-duration) var(--animation-ease);
}
.loader[aria-hidden=true] {
  opacity: 0;
  pointer-events: none;
}
.loader-logo {
  width: 128px;
  height: 128px;
  object-fit: contain;
}
.loader-yinyang {
  width: 96px;
  box-sizing: content-box;
  height: 48px;
  background: var(--body-bg);
  border-color: var(--base-primary);
  border-style: solid;
  border-width: 2px 2px 50px 2px;
  border-radius: 100%;
  position: relative;
  animation: loader-yinyang 3s linear infinite;
}
.loader-yinyang::before, .loader-yinyang::after {
  content: "";
  position: absolute;
  top: 50%;
  background: var(--body-bg);
  border: 18px solid var(--base-primary);
  border-radius: 100%;
  width: 12px;
  height: 12px;
  box-sizing: content-box;
}
.loader-yinyang::before {
  left: 0;
}
.loader-yinyang::after {
  left: 50%;
  background: var(--base-primary);
  border: 18px solid var(--body-bg);
}
@keyframes loader-yinyang {
  100% {
    transform: rotate(360deg);
  }
}
.loader-wave {
  width: 150px;
  height: 150px;
  background-color: var(--base-primary);
  border-radius: 50%;
  position: relative;
  box-shadow: 0 0 30px 4px rgba(0, 0, 0, 0.5) inset, 0 5px 12px rgba(0, 0, 0, 0.15);
  overflow: hidden;
}
.loader-wave::before, .loader-wave::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: 45%;
  top: -40%;
  background-color: var(--body-bg);
  animation: loader-wave 5s linear infinite;
}
.loader-wave::before {
  border-radius: 30%;
  background: color-mix(in srgb, var(--body-bg) 40%, transparent);
}
@keyframes loader-wave {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}
.loader-bounce {
  color: var(--body-color);
  position: relative;
  display: inline-block;
  margin-top: 40px;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 48px;
  letter-spacing: 4px;
  box-sizing: border-box;
}
.loader-bounce::after {
  content: "";
  width: 10px;
  height: 10px;
  position: absolute;
  left: 125px;
  top: 2px;
  border-radius: 50%;
  background: var(--base-primary);
  box-sizing: border-box;
  animation: loader-bounce-ball 1s linear infinite alternate;
}
@keyframes loader-bounce-ball {
  0% {
    transform: translate(0px, 0px) scaleX(1);
  }
  14% {
    transform: translate(-12px, -16px) scaleX(1.05);
  }
  28% {
    transform: translate(-27px, -28px) scaleX(1.07);
  }
  42% {
    transform: translate(-46px, -35px) scaleX(1.1);
  }
  57% {
    transform: translate(-70px, -37px) scaleX(1.1);
  }
  71% {
    transform: translate(-94px, -32px) scaleX(1.07);
  }
  85% {
    transform: translate(-111px, -22px) scaleX(1.05);
  }
  100% {
    transform: translate(-125px, -9px) scaleX(1);
  }
}
.loader-ring {
  display: inline-block;
  font-size: 48px;
  font-family: Arial, Helvetica, sans-serif;
  font-weight: bold;
  color: var(--body-color);
  position: relative;
  word-spacing: 36px;
}
.loader-ring::before {
  content: "";
  position: absolute;
  left: 38px;
  bottom: 8px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 5px solid var(--body-color);
  border-bottom-color: var(--base-primary);
  box-sizing: border-box;
  animation: loader-ring 0.6s linear infinite;
}
@keyframes loader-ring {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.h-25-dvh {
  height: 25dvh;
}
.h-min-25-dvh {
  min-height: 25dvh;
}
.h-max-25-dvh {
  max-height: 25dvh;
}
.h-50-dvh {
  height: 50dvh;
}
.h-min-50-dvh {
  min-height: 50dvh;
}
.h-max-50-dvh {
  max-height: 50dvh;
}
.h-75-dvh {
  height: 75dvh;
}
.h-min-75-dvh {
  min-height: 75dvh;
}
.h-max-75-dvh {
  max-height: 75dvh;
}
.h-100-dvh {
  height: 100dvh;
}
.h-min-100-dvh {
  min-height: 100dvh;
}
.h-max-100-dvh {
  max-height: 100dvh;
}
.h-25 {
  height: 25%;
}
.h-min-25 {
  min-height: 25%;
}
.h-max-25 {
  max-height: 25%;
}
.h-50 {
  height: 50%;
}
.h-min-50 {
  min-height: 50%;
}
.h-max-50 {
  max-height: 50%;
}
.h-75 {
  height: 75%;
}
.h-min-75 {
  min-height: 75%;
}
.h-max-75 {
  max-height: 75%;
}
.h-100 {
  height: 100%;
}
.h-min-100 {
  min-height: 100%;
}
.h-max-100 {
  max-height: 100%;
}
.h-auto {
  height: auto;
}
.h-min-auto {
  min-height: auto;
}
.h-max-auto {
  max-height: auto;
}
.h-min-content {
  height: min-content;
}
.h-max-content {
  height: max-content;
}
.h-fit-content {
  height: fit-content;
}
.h-1 {
  height: calc(var(--space-base) * 2);
}
.h-2 {
  height: calc(var(--space-base) * 4);
}
.h-3 {
  height: calc(var(--space-base) * 8);
}
.h-4 {
  height: calc(var(--space-base) * 12);
}
.h-5 {
  height: calc(var(--space-base) * 20);
}
.m-0 {
  margin: 0;
}
.m-1 {
  margin: var(--space-1);
}
.m-2 {
  margin: var(--space-2);
}
.m-3, .tile {
  margin: var(--space-3);
}
.m-4 {
  margin: var(--space-4);
}
.m-5 {
  margin: var(--space-5);
}
.m-auto {
  margin: auto;
}
.mh-0 {
  margin-inline: 0;
}
.mh-1 {
  margin-inline: var(--space-1);
}
.mh-2 {
  margin-inline: var(--space-2);
}
.mh-3 {
  margin-inline: var(--space-3);
}
.mh-4 {
  margin-inline: var(--space-4);
}
.mh-5 {
  margin-inline: var(--space-5);
}
.mh-auto {
  margin-inline: auto;
}
.mv-0 {
  margin-block: 0;
}
.mv-1 {
  margin-block: var(--space-1);
}
.mv-2 {
  margin-block: var(--space-2);
}
.mv-3 {
  margin-block: var(--space-3);
}
.mv-4 {
  margin-block: var(--space-4);
}
.mv-5 {
  margin-block: var(--space-5);
}
.mv-auto {
  margin-block: auto;
}
.ms-0 {
  margin-inline-start: 0;
}
.ms-1 {
  margin-inline-start: var(--space-1);
}
.ms-2 {
  margin-inline-start: var(--space-2);
}
.ms-3 {
  margin-inline-start: var(--space-3);
}
.ms-4 {
  margin-inline-start: var(--space-4);
}
.ms-5 {
  margin-inline-start: var(--space-5);
}
.ms-auto {
  margin-inline-start: auto;
}
.me-0 {
  margin-inline-end: 0;
}
.me-1 {
  margin-inline-end: var(--space-1);
}
.me-2 {
  margin-inline-end: var(--space-2);
}
.me-3 {
  margin-inline-end: var(--space-3);
}
.me-4 {
  margin-inline-end: var(--space-4);
}
.me-5 {
  margin-inline-end: var(--space-5);
}
.me-auto {
  margin-inline-end: auto;
}
.mt-0 {
  margin-block-start: 0;
}
.mt-1 {
  margin-block-start: var(--space-1);
}
.mt-2 {
  margin-block-start: var(--space-2);
}
.mt-3 {
  margin-block-start: var(--space-3);
}
.mt-4 {
  margin-block-start: var(--space-4);
}
.mt-5 {
  margin-block-start: var(--space-5);
}
.mt-auto {
  margin-block-start: auto;
}
.mb-0 {
  margin-block-end: 0;
}
.mb-1 {
  margin-block-end: var(--space-1);
}
.mb-2 {
  margin-block-end: var(--space-2);
}
.mb-3 {
  margin-block-end: var(--space-3);
}
.mb-4 {
  margin-block-end: var(--space-4);
}
.mb-5 {
  margin-block-end: var(--space-5);
}
.mb-auto {
  margin-block-end: auto;
}
.object-fit-contain {
  object-fit: contain;
}
.object-fit-cover {
  object-fit: cover;
}
.object-fit-fill {
  object-fit: fill;
}
.object-fit-scale-down {
  object-fit: scale-down;
}
.object-fit-none {
  object-fit: none;
}
.opacity-25 {
  opacity: 0.25;
}
.opacity-50 {
  opacity: 0.5;
}
.opacity-75, .footer-brand p, .footer-bar {
  opacity: 0.75;
}
.p-1 {
  padding: var(--space-1);
}
.p-2 {
  padding: var(--space-2);
}
.p-3, .tile {
  padding: var(--space-3);
}
.p-4 {
  padding: var(--space-4);
}
.p-5 {
  padding: var(--space-5);
}
.ph-1 {
  padding-inline: var(--space-1);
}
.ph-2 {
  padding-inline: var(--space-2);
}
.ph-3 {
  padding-inline: var(--space-3);
}
.ph-4 {
  padding-inline: var(--space-4);
}
.ph-5 {
  padding-inline: var(--space-5);
}
.pv-1 {
  padding-block: var(--space-1);
}
.pv-2 {
  padding-block: var(--space-2);
}
.pv-3 {
  padding-block: var(--space-3);
}
.pv-4 {
  padding-block: var(--space-4);
}
.pv-5 {
  padding-block: var(--space-5);
}
.ps-1 {
  padding-inline-start: var(--space-1);
}
.ps-2 {
  padding-inline-start: var(--space-2);
}
.ps-3 {
  padding-inline-start: var(--space-3);
}
.ps-4 {
  padding-inline-start: var(--space-4);
}
.ps-5 {
  padding-inline-start: var(--space-5);
}
.pe-1 {
  padding-inline-end: var(--space-1);
}
.pe-2 {
  padding-inline-end: var(--space-2);
}
.pe-3 {
  padding-inline-end: var(--space-3);
}
.pe-4 {
  padding-inline-end: var(--space-4);
}
.pe-5 {
  padding-inline-end: var(--space-5);
}
.pt-1 {
  padding-block-start: var(--space-1);
}
.pt-2 {
  padding-block-start: var(--space-2);
}
.pt-3 {
  padding-block-start: var(--space-3);
}
.pt-4 {
  padding-block-start: var(--space-4);
}
.pt-5 {
  padding-block-start: var(--space-5);
}
.pb-1 {
  padding-block-end: var(--space-1);
}
.pb-2 {
  padding-block-end: var(--space-2);
}
.pb-3 {
  padding-block-end: var(--space-3);
}
.pb-4 {
  padding-block-end: var(--space-4);
}
.pb-5 {
  padding-block-end: var(--space-5);
}
.p-0 {
  padding: 0;
}
.ph-0 {
  padding-inline: 0;
}
.pv-0 {
  padding-block: 0;
}
.ps-0 {
  padding-inline-start: 0;
}
.pe-0 {
  padding-inline-end: 0;
}
.pt-0 {
  padding-block-start: 0;
}
.pb-0 {
  padding-block-end: 0;
}
.pe-none {
  pointer-events: none;
}
.pe-auto {
  pointer-events: auto;
}
.sticky-top {
  position: sticky;
  inset-block-start: 0;
  z-index: 250;
}
.sticky-bottom {
  position: sticky;
  inset-block-end: 0;
  z-index: 250;
}
.fixed-top {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 251;
}
.fixed-bottom {
  position: fixed;
  inset-block-end: 0;
  inset-inline: 0;
  z-index: 251;
}
.position-static {
  position: static;
}
.position-relative {
  position: relative;
}
.position-absolute {
  position: absolute;
}
.position-fixed {
  position: fixed;
}
.position-sticky {
  position: sticky;
}
.top-0 {
  inset-block-start: 0;
}
.bottom-0 {
  inset-block-end: 0;
}
.start-0 {
  inset-inline-start: 0;
}
.end-0 {
  inset-inline-end: 0;
}
.top-50 {
  inset-block-start: 50%;
}
.bottom-50 {
  inset-block-end: 50%;
}
.start-50 {
  inset-inline-start: 50%;
}
.end-50 {
  inset-inline-end: 50%;
}
.top-100 {
  inset-block-start: 100%;
}
.bottom-100 {
  inset-block-end: 100%;
}
.start-100 {
  inset-inline-start: 100%;
}
.end-100 {
  inset-inline-end: 100%;
}
.translate-middle {
  transform: translate(-50%, -50%);
}
.translate-middle-x {
  transform: translateX(-50%);
}
.translate-middle-y {
  transform: translateY(-50%);
}
.print-only {
  display: none;
}
.ratio-1x1 {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
}
.ratio-1x1 > * {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.ratio-1x1 > img {
  display: block;
  object-fit: cover;
}
.ratio-4x3 {
  position: relative;
  width: 100%;
  aspect-ratio: 4/3;
}
.ratio-4x3 > * {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.ratio-4x3 > img {
  display: block;
  object-fit: cover;
}
.ratio-16x9 {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
}
.ratio-16x9 > * {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.ratio-16x9 > img {
  display: block;
  object-fit: cover;
}
.ratio-21x9 {
  position: relative;
  width: 100%;
  aspect-ratio: 21/9;
}
.ratio-21x9 > * {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.ratio-21x9 > img {
  display: block;
  object-fit: cover;
}
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  scrollbar-gutter: stable;
}
* {
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--body-color) 40%, transparent) transparent;
}
*::-webkit-scrollbar {
  width: 2px;
  height: 2px;
}
*::-webkit-scrollbar-track {
  background: transparent;
}
*::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--body-color) 40%, transparent);
}
*::-webkit-scrollbar-button {
  display: none;
}
.scroll-auto {
  scroll-behavior: auto;
}
.scroll-smooth {
  scroll-behavior: smooth;
}
.overflow-auto {
  overflow: auto;
}
.overflow-hidden {
  overflow: hidden;
}
.overflow-visible {
  overflow: visible;
}
.overflow-scroll {
  overflow: scroll;
}
.overflow-x-auto {
  overflow-x: auto;
}
.overflow-x-hidden {
  overflow-x: hidden;
}
.overflow-x-visible {
  overflow-x: visible;
}
.overflow-x-scroll {
  overflow-x: scroll;
}
.overflow-y-auto {
  overflow-y: auto;
}
.overflow-y-hidden {
  overflow-y: hidden;
}
.overflow-y-visible {
  overflow-y: visible;
}
.overflow-y-scroll {
  overflow-y: scroll;
}
.corner, .tile {
  border-radius: var(--border-radius);
}
.pill {
  border-radius: 50rem;
}
.circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  aspect-ratio: 1/1;
  text-align: center;
}
.square-1 {
  width: calc(var(--space-base) * 2);
  height: calc(var(--space-base) * 2);
}
.square-2 {
  width: calc(var(--space-base) * 4);
  height: calc(var(--space-base) * 4);
}
.square-3 {
  width: calc(var(--space-base) * 8);
  height: calc(var(--space-base) * 8);
}
.square-4 {
  width: calc(var(--space-base) * 12);
  height: calc(var(--space-base) * 12);
}
.square-5 {
  width: calc(var(--space-base) * 20);
  height: calc(var(--space-base) * 20);
}
:not(.flex):has(> .spacer) {
  display: flex;
  flex-direction: column;
}
.spacer {
  flex: 1;
}
/* ── Tactile ──────────────────────────────────────────────────────
   Surface-aware press feedback. Pure CSS - no JavaScript required.

   Applied automatically to .button and .menu-link via @include
   tactile in their own SCSS. Any element can opt in by
   adding the .tactile class.

   Each surface gets a distinct press effect:
     flat      - background overlay that fills the element shape
     material  - MD3 expanding ink circle from center
     neo       - elevation lift on hover, return on press

   prefers-reduced-motion: animations use --animation-duration
   which is set to 0ms centrally when reduced motion is preferred.
   ─────────────────────────────────────────────────────────────────── */
/* Container: any element that wants tactile must clip the overlay */
.tactile {
  position: relative;
  overflow: hidden;
  cursor: pointer;
}
.tactile::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: currentcolor;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.97);
  transition: opacity calc(var(--animation-duration) * 2) var(--animation-ease), transform calc(var(--animation-duration) * 2) var(--animation-ease);
}
.tactile:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.1;
  transform: scale(1);
  transition: none;
}
.tactile-demo-flat::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: currentcolor;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.97);
  transition: opacity calc(var(--animation-duration) * 2) var(--animation-ease), transform calc(var(--animation-duration) * 2) var(--animation-ease);
}
.tactile-demo-flat:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.1;
  transform: scale(1);
  transition: none;
}
.tactile-demo-material::before {
  border-radius: 50%;
  transform: scale(0);
}
.tactile-demo-material:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.14;
  transform: scale(2.5);
}
.tactile-demo-neo {
  transition: box-shadow var(--animation-duration) var(--animation-ease), translate var(--animation-duration) var(--animation-ease);
}
.tactile-demo-neo::before {
  display: none;
}
.tactile-demo-neo:hover:not(:active):not(:disabled):not([aria-disabled=true]) {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  translate: 0 -2px;
}
details > summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2);
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius);
}
details > summary::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: currentcolor;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.97);
  transition: opacity calc(var(--animation-duration) * 2) var(--animation-ease), transform calc(var(--animation-duration) * 2) var(--animation-ease);
}
details > summary:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.1;
  transform: scale(1);
  transition: none;
}
details > summary::marker {
  content: "";
}
details > summary::after {
  content: "";
  inline-size: 0.5rem;
  block-size: 0.5rem;
  border-inline-end: 1px solid currentColor;
  border-block-end: 1px solid currentColor;
  transform: rotate(45deg);
  transition: transform calc(var(--animation-duration) * 4) var(--animation-ease);
}
details > summary:hover::after {
  will-change: transform;
}
details > :not(summary) {
  padding: var(--space-2);
}
details[open] > summary::after {
  transform: rotate(-135deg);
  transition: transform var(--animation-duration) var(--animation-ease);
}
figure,
.figure {
  border-radius: var(--border-radius);
  overflow: hidden;
  border: var(--border-width) solid currentcolor;
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--body-color) var(--elevation-mix), transparent);
}
figure > div,
.figure > div {
  min-block-size: 3rem;
  background: currentcolor;
}
figure img,
figure svg,
.figure-img {
  inline-size: 100%;
  display: block;
  margin-block-end: var(--space-1);
  line-height: 1;
}
figcaption,
.figure-caption {
  padding: var(--space-2);
  font-size: 0.875em;
  color: color-mix(in srgb, var(--body-color) 65%, transparent);
}
.visible-phone {
  display: block;
}
.hidden-phone {
  display: none;
}
.visible-tablet {
  display: none;
}
.hidden-tablet {
  display: block;
}
.visible-laptop {
  display: none;
}
.hidden-laptop {
  display: block;
}
.visible-desktop {
  display: none;
}
.hidden-desktop {
  display: block;
}
.visible-wall {
  display: none;
}
.hidden-wall {
  display: block;
}
.visible-ultra {
  display: none;
}
.hidden-ultra {
  display: block;
}
.visible {
  visibility: visible;
}
.invisible {
  visibility: hidden;
}
.visually-hidden,
.visually-hidden-focusable:not(:focus):not(:focus-within) {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}
.w-25-vw {
  width: 25vw;
}
.w-min-25-vw {
  min-width: 25vw;
}
.w-max-25-vw {
  max-width: 25vw;
}
.w-50-vw {
  width: 50vw;
}
.w-min-50-vw {
  min-width: 50vw;
}
.w-max-50-vw {
  max-width: 50vw;
}
.w-75-vw {
  width: 75vw;
}
.w-min-75-vw {
  min-width: 75vw;
}
.w-max-75-vw {
  max-width: 75vw;
}
.w-100-vw {
  width: 100vw;
}
.w-min-100-vw {
  min-width: 100vw;
}
.w-max-100-vw {
  max-width: 100vw;
}
.w-25 {
  width: 25%;
}
.w-min-25 {
  min-width: 25%;
}
.w-max-25 {
  max-width: 25%;
}
.w-50 {
  width: 50%;
}
.w-min-50 {
  min-width: 50%;
}
.w-max-50 {
  max-width: 50%;
}
.w-75 {
  width: 75%;
}
.w-min-75 {
  min-width: 75%;
}
.w-max-75 {
  max-width: 75%;
}
.w-100 {
  width: 100%;
}
.w-min-100 {
  min-width: 100%;
}
.w-max-100 {
  max-width: 100%;
}
.w-auto {
  width: auto;
}
.w-min-auto {
  min-width: auto;
}
.w-max-auto {
  max-width: auto;
}
.w-min-content {
  width: min-content;
}
.w-max-content {
  width: max-content;
}
.w-fit-content {
  width: fit-content;
}
.w-1 {
  width: calc(var(--space-base) * 2);
}
.w-2 {
  width: calc(var(--space-base) * 4);
}
.w-3 {
  width: calc(var(--space-base) * 8);
}
.w-4 {
  width: calc(var(--space-base) * 12);
}
.w-5 {
  width: calc(var(--space-base) * 20);
}
.z-below {
  z-index: -1;
}
.z-base {
  z-index: 0;
}
.z-raised {
  z-index: 10;
}
.z-dropdown {
  z-index: 100;
}
.z-header {
  z-index: 150;
}
.z-sidebar {
  z-index: 200;
}
.z-sticky {
  z-index: 250;
}
.z-fixed {
  z-index: 251;
}
.z-navbar {
  z-index: 300;
}
.z-overlay {
  z-index: 400;
}
.z-backdrop {
  z-index: 425;
}
.z-drawer {
  z-index: 450;
}
.z-modal {
  z-index: 500;
}
.z-toast {
  z-index: 600;
}
.z-tooltip {
  z-index: 700;
}
.z-critical {
  z-index: 1000;
}
.form-label {
  display: inline-block;
  margin-block-end: var(--space-1);
  font-weight: 500;
}
.form-text {
  display: block;
  margin-block-start: var(--space-1);
  font-size: 0.875em;
  color: color-mix(in srgb, var(--body-color) 65%, transparent);
}
.form-control,
.form-select,
input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=hidden]),
select,
textarea {
  display: block;
  inline-size: 100%;
  padding-block: var(--space-2);
  padding-inline: var(--space-3);
  font-family: inherit;
  font-size: inherit;
  font-weight: 400;
  line-height: 1.5;
  color: var(--body-color);
  background-color: var(--body-bg);
  background-clip: padding-box;
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
  appearance: none;
  transition: border-color var(--animation-duration) var(--animation-ease), box-shadow var(--animation-duration) var(--animation-ease);
}
.form-control:focus,
.form-select:focus,
input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=hidden]):focus,
select:focus,
textarea:focus {
  color: var(--body-color);
  background-color: var(--body-bg);
  border-color: var(--base-primary);
  outline: 0;
  box-shadow: 0 0 0 var(--border-width) color-mix(in srgb, var(--base-primary) 25%, transparent);
}
.form-control::placeholder,
.form-select::placeholder,
input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=hidden])::placeholder,
select::placeholder,
textarea::placeholder {
  color: color-mix(in srgb, var(--body-color) 50%, transparent);
  opacity: 1;
}
.form-control:disabled, .form-control[readonly],
.form-select:disabled,
.form-select[readonly],
input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=hidden]):disabled,
input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=hidden])[readonly],
select:disabled,
select[readonly],
textarea:disabled,
textarea[readonly] {
  background-color: color-mix(in srgb, var(--body-color) 5%, var(--body-bg));
  opacity: 1;
}
.form-select, select {
  padding-inline-end: calc(var(--space-3) * 3);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  background-size: 1em;
}
textarea.form-control, textarea {
  min-block-size: calc(var(--space-base) * 10);
  resize: vertical;
}
.form-control[type=file] {
  overflow: hidden;
}
.form-control[type=file]:not(:disabled):not([readonly]) {
  cursor: pointer;
}
.form-control-sm,
.form-select-sm {
  padding-block: var(--space-1);
  padding-inline: var(--space-2);
  font-size: 0.875em;
}
.form-control-lg,
.form-select-lg {
  padding-block: var(--space-3);
  padding-inline: var(--space-4);
  font-size: 1.125em;
}
.form-check {
  display: block;
  min-block-size: 1.5rem;
  padding-inline-start: 1.5em;
  margin-block-end: var(--space-1);
}
.form-check-label {
  cursor: pointer;
}
.form-check-input {
  inline-size: 1em;
  block-size: 1em;
  margin-block-start: 0.25em;
  margin-inline-start: -1.5em;
  background-color: var(--body-bg);
  border: var(--border-width) solid var(--body-color);
  appearance: none;
  cursor: pointer;
  transition: background-color var(--animation-duration) var(--animation-ease), border-color var(--animation-duration) var(--animation-ease), box-shadow var(--animation-duration) var(--animation-ease);
}
.form-check-input[type=checkbox] {
  border-radius: 0.25em;
}
.form-check-input[type=radio] {
  border-radius: 50%;
}
.form-check-input:checked {
  background-color: var(--base-primary);
  border-color: var(--base-primary);
}
.form-check-input:focus {
  outline: 0;
  box-shadow: 0 0 0 var(--border-width) color-mix(in srgb, var(--base-primary) 25%, transparent);
}
.form-check-input:disabled {
  opacity: 0.5;
  pointer-events: none;
}
.form-check-input:disabled ~ .form-check-label {
  cursor: default;
  opacity: 0.5;
}
.form-switch {
  padding-inline-start: 2.5em;
}
.form-switch .form-check-input {
  inline-size: 2em;
  margin-inline-start: -2.5em;
  border-radius: 2em;
  background-position: left center;
  background-size: contain;
  transition: background-color var(--animation-duration) var(--animation-ease), background-position var(--animation-duration) var(--animation-ease), border-color var(--animation-duration) var(--animation-ease);
}
.form-switch .form-check-input:checked {
  background-position: right center;
}
.form-range {
  inline-size: 100%;
  appearance: none;
  background-color: transparent;
}
.form-range:focus {
  outline: 0;
}
.form-range:disabled {
  opacity: 0.5;
}
.input-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  inline-size: 100%;
}
.input-group > .form-control,
.input-group > .form-select {
  position: relative;
  flex: 1 1 auto;
  inline-size: 1%;
  min-inline-size: 0;
}
.input-group > :not(:first-child) {
  margin-inline-start: calc(var(--border-width) * -1);
  border-start-start-radius: 0;
  border-end-start-radius: 0;
}
.input-group > :not(:last-child) {
  border-start-end-radius: 0;
  border-end-end-radius: 0;
}
.input-group-text {
  display: flex;
  align-items: center;
  padding-block: var(--space-2);
  padding-inline: var(--space-3);
  font-size: inherit;
  font-weight: 400;
  line-height: 1.5;
  color: var(--body-color);
  text-align: center;
  white-space: nowrap;
  background-color: color-mix(in srgb, var(--body-color) 5%, var(--body-bg));
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
}
.form-floating {
  position: relative;
}
.form-floating > .form-control,
.form-floating > .form-select {
  block-size: calc(3.5rem + var(--border-width) * 2);
  padding-block: 1rem;
  padding-inline: var(--space-3);
}
.form-floating > label {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: 2;
  block-size: 100%;
  padding-block: 1rem;
  padding-inline: var(--space-3);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  pointer-events: none;
  transform-origin: 0 0;
  transition: opacity var(--animation-duration) var(--animation-ease), transform var(--animation-duration) var(--animation-ease);
}
.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label,
.form-floating > .form-select ~ label {
  opacity: 0.65;
  transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem);
}
.valid-feedback,
.invalid-feedback {
  display: none;
  inline-size: 100%;
  margin-block-start: var(--space-1);
  font-size: 0.875em;
}
.valid-feedback {
  color: var(--base-success);
}
.invalid-feedback {
  color: var(--base-danger);
}
.was-validated :valid,
.is-valid {
  border-color: var(--base-success);
}
.was-validated :valid:focus,
.is-valid:focus {
  box-shadow: 0 0 0 var(--border-width) color-mix(in srgb, var(--base-success) 25%, transparent);
}
.was-validated :invalid,
.is-invalid {
  border-color: var(--base-danger);
}
.was-validated :invalid:focus,
.is-invalid:focus {
  box-shadow: 0 0 0 var(--border-width) color-mix(in srgb, var(--base-danger) 25%, transparent);
}
.was-validated :valid ~ .valid-feedback,
.is-valid ~ .valid-feedback {
  display: block;
}
.was-validated :invalid ~ .invalid-feedback,
.is-invalid ~ .invalid-feedback {
  display: block;
}
form {
  margin: 0;
}
fieldset {
  min-inline-size: 0;
  padding: var(--space-3);
  margin: 0;
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
}
legend {
  display: block;
  padding-inline: var(--space-1);
  margin-block-end: var(--space-2);
  font-size: 1.125em;
  font-weight: 500;
  line-height: inherit;
}
datalist {
  display: none;
}
optgroup {
  font-weight: 500;
}
option {
  font-weight: 400;
}
search {
  display: block;
}
.inline-edit {
  display: inline-flex;
  align-items: center;
  min-inline-size: 4ch;
  padding-block: var(--space-1);
  padding-inline: var(--space-1);
  font: inherit;
  color: inherit;
  line-height: inherit;
  cursor: pointer;
  border-block-end: var(--border-width) dashed color-mix(in srgb, currentcolor 40%, transparent);
  border-radius: 0;
  transition: border-color var(--animation-duration) var(--animation-ease), background-color var(--animation-duration) var(--animation-ease);
}
.inline-edit:hover:not(.inline-edit-disabled) {
  border-block-end-color: currentcolor;
  background-color: color-mix(in srgb, currentcolor 5%, transparent);
}
.inline-edit:focus-visible {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
}
.inline-edit-editing {
  cursor: text;
  border: var(--border-width) solid var(--primary-color);
  border-radius: var(--border-radius);
  background-color: var(--body-bg);
  padding-block: var(--space-1);
  padding-inline: var(--space-2);
}
.inline-edit-editing:focus {
  outline: 2px solid var(--primary-color);
  outline-offset: 2px;
}
.inline-edit-disabled {
  cursor: default;
  opacity: 0.5;
  border-block-end-style: dotted;
}
.inline-edit-placeholder {
  opacity: 0.5;
  font-style: italic;
}
.rich-text-editor {
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
  overflow: hidden;
}
.rich-text-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  padding: var(--space-2);
  border-block-end: var(--border-width) solid var(--body-color);
  background-color: color-mix(in srgb, var(--body-color) 3%, var(--body-bg));
}
.rich-text-toolbar button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 2rem;
  block-size: 2rem;
  border: none;
  border-radius: var(--border-radius);
  background: none;
  color: var(--body-color);
  cursor: pointer;
  transition: background-color var(--animation-duration) var(--animation-ease);
}
.rich-text-toolbar button:hover {
  background-color: color-mix(in srgb, var(--body-color) 10%, var(--body-bg));
}
.rich-text-toolbar button.active {
  background-color: var(--base-primary);
  color: var(--body-bg);
}
.rich-text-content {
  min-block-size: 12rem;
  padding: var(--space-3);
  outline: none;
  font: inherit;
}
.rich-text-content:focus {
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--base-primary) 25%, transparent);
}
.rich-text-content[contenteditable] {
  cursor: text;
}
.rich-text-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  min-block-size: 12rem;
  color: color-mix(in srgb, var(--body-color) 40%, transparent);
  font-size: 0.875em;
}
.album {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
  inline-size: 100%;
}
.album-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius);
  background-color: var(--surface-primary-bg);
  border: var(--border-width) solid var(--body-color);
}
.album-item img {
  display: block;
  inline-size: 100%;
  block-size: auto;
  object-fit: cover;
  aspect-ratio: 4/3;
}
.album-caption {
  padding: var(--space-2) var(--space-3);
}
.callout {
  position: relative;
  padding-block: var(--space-3);
  padding-inline: var(--space-4);
  margin-block-end: var(--space-3);
  border: var(--border-width) solid transparent;
  border-radius: var(--border-radius);
  transition: opacity var(--animation-duration) var(--animation-ease);
}
.callout a {
  font-weight: 700;
  color: inherit;
}
.callout-dismissible {
  padding-inline-end: calc(var(--space-4) * 3);
}
.callout-dismissible .callout-close {
  position: absolute;
  inset-block-start: 0;
  inset-inline-end: 0;
  padding: var(--space-3) var(--space-4);
  background: none;
  border: 0;
  cursor: pointer;
  opacity: 0.5;
}
.callout-dismissible .callout-close:hover {
  opacity: 0.75;
}
.callout-primary {
  color: var(--primary-color);
  background-color: color-mix(in srgb, var(--primary-bg) 15%, var(--body-bg));
  border-color: color-mix(in srgb, var(--primary-bg) 30%, var(--body-bg));
}
.callout-secondary {
  color: var(--secondary-color);
  background-color: color-mix(in srgb, var(--secondary-bg) 15%, var(--body-bg));
  border-color: color-mix(in srgb, var(--secondary-bg) 30%, var(--body-bg));
}
.callout-tertiary {
  color: var(--tertiary-color);
  background-color: color-mix(in srgb, var(--tertiary-bg) 15%, var(--body-bg));
  border-color: color-mix(in srgb, var(--tertiary-bg) 30%, var(--body-bg));
}
.callout-success {
  color: var(--success-color);
  background-color: color-mix(in srgb, var(--success-bg) 15%, var(--body-bg));
  border-color: color-mix(in srgb, var(--success-bg) 30%, var(--body-bg));
}
.callout-info {
  color: var(--info-color);
  background-color: color-mix(in srgb, var(--info-bg) 15%, var(--body-bg));
  border-color: color-mix(in srgb, var(--info-bg) 30%, var(--body-bg));
}
.callout-warning {
  color: var(--warning-color);
  background-color: color-mix(in srgb, var(--warning-bg) 15%, var(--body-bg));
  border-color: color-mix(in srgb, var(--warning-bg) 30%, var(--body-bg));
}
.callout-danger {
  color: var(--danger-color);
  background-color: color-mix(in srgb, var(--danger-bg) 15%, var(--body-bg));
  border-color: color-mix(in srgb, var(--danger-bg) 30%, var(--body-bg));
}
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding-block: 0.35em;
  padding-inline: 0.65em;
  font-size: 0.75em;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: var(--border-radius);
  transition: color var(--animation-duration) var(--animation-ease), background-color var(--animation-duration) var(--animation-ease);
}
.badge:empty {
  display: none;
}
.badge-pill {
  border-radius: 50rem;
}
.badge-primary {
  background-color: var(--primary-bg);
  color: var(--body-bg);
}
.badge-secondary {
  background-color: var(--secondary-bg);
  color: var(--body-bg);
}
.badge-tertiary {
  background-color: var(--tertiary-bg);
  color: var(--body-bg);
}
.badge-success {
  background-color: var(--success-bg);
  color: var(--body-bg);
}
.badge-info {
  background-color: var(--info-bg);
  color: var(--body-bg);
}
.badge-warning {
  background-color: var(--warning-bg);
  color: var(--body-bg);
}
.badge-danger {
  background-color: var(--danger-bg);
  color: var(--body-bg);
}
.badge-body {
  background-color: var(--body-bg);
  color: var(--body-color);
}
.badge-surface-primary {
  background-color: var(--surface-primary-bg);
  color: var(--surface-primary-color);
}
.badge-surface-secondary {
  background-color: var(--surface-secondary-bg);
  color: var(--surface-secondary-color);
}
.badge-outlined {
  background-color: transparent;
  border: var(--border-width) solid currentcolor;
}
.badge-outlined.badge-primary {
  color: var(--primary-color);
  background-color: transparent;
}
.badge-outlined.badge-secondary {
  color: var(--secondary-color);
  background-color: transparent;
}
.badge-outlined.badge-tertiary {
  color: var(--tertiary-color);
  background-color: transparent;
}
.badge-outlined.badge-success {
  color: var(--success-color);
  background-color: transparent;
}
.badge-outlined.badge-info {
  color: var(--info-color);
  background-color: transparent;
}
.badge-outlined.badge-warning {
  color: var(--warning-color);
  background-color: transparent;
}
.badge-outlined.badge-danger {
  color: var(--danger-color);
  background-color: transparent;
}
.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  margin-block-end: var(--space-3);
  font-size: inherit;
  list-style: none;
}
.breadcrumb-item + .breadcrumb-item {
  padding-inline-start: var(--space-2);
}
.breadcrumb-item + .breadcrumb-item::before {
  float: inline-start;
  padding-inline-end: var(--space-2);
  color: color-mix(in srgb, var(--body-color) 50%, transparent);
  content: var(--breadcrumb-divider, "/");
}
.breadcrumb-item.active, .breadcrumb-item[aria-current=page] {
  color: color-mix(in srgb, var(--body-color) 50%, transparent);
}
.breadcrumb-overflow {
  position: relative;
}
.breadcrumb-overflow .breadcrumb-overflow-toggle {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  color: inherit;
  font: inherit;
  letter-spacing: 0.1em;
}
.breadcrumb-overflow .breadcrumb-overflow-toggle:hover {
  color: var(--base-primary);
}
.breadcrumb-overflow .breadcrumb-overflow-toggle:focus-visible {
  outline: 2px solid var(--base-primary);
  outline-offset: 2px;
}
.breadcrumb-overflow .breadcrumb-overflow-menu {
  position: absolute;
  z-index: 10;
  display: none;
  min-inline-size: 12rem;
  padding-block: var(--space-1);
  background-color: var(--body-bg);
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  list-style: none;
}
[aria-expanded=true] + .breadcrumb-overflow .breadcrumb-overflow-menu {
  display: block;
}
.breadcrumb-overflow .breadcrumb-overflow-menu a {
  display: block;
  padding: var(--space-1) var(--space-3);
  text-decoration: none;
  color: var(--body-color);
}
.breadcrumb-overflow .breadcrumb-overflow-menu a:hover {
  background-color: color-mix(in srgb, var(--body-color) 5%, var(--body-bg));
}
.button, button {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  min-block-size: calc(var(--space-base) * 5);
  padding-block: var(--space-1);
  padding-inline: var(--space-3);
  font-family: inherit;
  font-size: calc(var(--space-base) * 1.75);
  font-weight: 500;
  line-height: calc(var(--space-base) * 2.5);
  text-decoration: none;
  color: inherit;
  background: transparent;
  border: 0;
  border-radius: var(--border-radius);
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: background-color var(--animation-duration) var(--animation-ease), border-color var(--animation-duration) var(--animation-ease), color var(--animation-duration) var(--animation-ease), box-shadow var(--animation-duration) var(--animation-ease), opacity var(--animation-duration) var(--animation-ease);
}
.button::before, button::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: currentcolor;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.97);
  transition: opacity calc(var(--animation-duration) * 2) var(--animation-ease), transform calc(var(--animation-duration) * 2) var(--animation-ease);
}
.button:active:not(:disabled):not([aria-disabled=true])::before, button:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.1;
  transform: scale(1);
  transition: none;
}
.button:hover, button:hover {
  background: color-mix(in srgb, currentcolor 8%, transparent);
}
.button:active, button:active {
  background: color-mix(in srgb, currentcolor 12%, transparent);
}
.button:focus-visible, button:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 var(--border-width) color-mix(in srgb, currentcolor 12%, transparent);
}
.button:disabled, .button[aria-disabled=true], button:disabled, button[aria-disabled=true] {
  opacity: 0.38;
  pointer-events: none;
}
.button > .graphic, button > .graphic {
  width: calc(var(--space-base) * 2.25);
  height: calc(var(--space-base) * 2.25);
  font-size: calc(var(--space-base) * 2.25);
}
.button-outlined {
  border: var(--border-width) solid currentcolor;
}
.button-filled {
  background-color: var(--body-color);
  color: var(--body-bg);
}
.button-filled:hover {
  background-color: color-mix(in srgb, var(--body-color) 92%, var(--body-bg));
}
.button-filled:active {
  background-color: color-mix(in srgb, var(--body-color) 88%, var(--body-bg));
}
.button-link {
  background: transparent;
  text-decoration: underline;
}
.button-link:hover {
  background: transparent;
  text-decoration: none;
}
.button-link:active {
  background: transparent;
}
.button-fab {
  min-block-size: calc(var(--space-base) * 7);
  min-inline-size: calc(var(--space-base) * 7);
  padding: var(--space-2);
  border-radius: var(--border-radius);
  background-color: var(--body-color);
  color: var(--body-bg);
}
.button-fab > .graphic {
  width: calc(var(--space-base) * 3);
  height: calc(var(--space-base) * 3);
  font-size: calc(var(--space-base) * 3);
}
.button-fab:hover {
  background-color: color-mix(in srgb, var(--body-color) 92%, var(--body-bg));
}
.button-fab:active {
  background-color: color-mix(in srgb, var(--body-color) 88%, var(--body-bg));
}
.button-outlined-body {
  color: var(--body-color);
}
.button-filled-body,
.button-fab-body {
  background-color: var(--body-bg);
  color: var(--body-color);
}
.button-filled-body:hover,
.button-fab-body:hover {
  background-color: color-mix(in srgb, var(--body-bg) 85%, var(--body-color));
}
.button-filled-body:active,
.button-fab-body:active {
  background-color: color-mix(in srgb, var(--body-bg) 75%, var(--body-color));
}
.button-link-body {
  color: var(--body-color);
}
.button-outlined-surface-primary {
  color: var(--surface-primary-color);
}
.button-filled-surface-primary,
.button-fab-surface-primary {
  background-color: var(--surface-primary-bg);
  color: var(--surface-primary-color);
}
.button-filled-surface-primary:hover,
.button-fab-surface-primary:hover {
  background-color: color-mix(in srgb, var(--surface-primary-bg) 85%, var(--body-color));
}
.button-filled-surface-primary:active,
.button-fab-surface-primary:active {
  background-color: color-mix(in srgb, var(--surface-primary-bg) 75%, var(--body-color));
}
.button-link-surface-primary {
  color: var(--surface-primary-color);
}
.button-outlined-surface-secondary {
  color: var(--surface-secondary-color);
}
.button-filled-surface-secondary,
.button-fab-surface-secondary {
  background-color: var(--surface-secondary-bg);
  color: var(--surface-secondary-color);
}
.button-filled-surface-secondary:hover,
.button-fab-surface-secondary:hover {
  background-color: color-mix(in srgb, var(--surface-secondary-bg) 85%, var(--body-color));
}
.button-filled-surface-secondary:active,
.button-fab-surface-secondary:active {
  background-color: color-mix(in srgb, var(--surface-secondary-bg) 75%, var(--body-color));
}
.button-link-surface-secondary {
  color: var(--surface-secondary-color);
}
.button-outlined-primary {
  color: var(--base-primary);
}
.button-filled-primary,
.button-fab-primary {
  background-color: var(--primary-bg);
  color: var(--body-bg);
}
.button-filled-primary:hover,
.button-fab-primary:hover {
  background-color: color-mix(in srgb, var(--primary-bg) 85%, var(--body-color));
}
.button-filled-primary:active,
.button-fab-primary:active {
  background-color: color-mix(in srgb, var(--primary-bg) 75%, var(--body-color));
}
.button-link-primary {
  color: var(--base-primary);
}
.button-link-primary:hover {
  color: color-mix(in srgb, var(--base-primary) 80%, var(--body-color));
}
.button-outlined-secondary {
  color: var(--base-secondary);
}
.button-filled-secondary,
.button-fab-secondary {
  background-color: var(--secondary-bg);
  color: var(--body-bg);
}
.button-filled-secondary:hover,
.button-fab-secondary:hover {
  background-color: color-mix(in srgb, var(--secondary-bg) 85%, var(--body-color));
}
.button-filled-secondary:active,
.button-fab-secondary:active {
  background-color: color-mix(in srgb, var(--secondary-bg) 75%, var(--body-color));
}
.button-link-secondary {
  color: var(--base-secondary);
}
.button-link-secondary:hover {
  color: color-mix(in srgb, var(--base-secondary) 80%, var(--body-color));
}
.button-outlined-tertiary {
  color: var(--base-tertiary);
}
.button-filled-tertiary,
.button-fab-tertiary {
  background-color: var(--tertiary-bg);
  color: var(--body-bg);
}
.button-filled-tertiary:hover,
.button-fab-tertiary:hover {
  background-color: color-mix(in srgb, var(--tertiary-bg) 85%, var(--body-color));
}
.button-filled-tertiary:active,
.button-fab-tertiary:active {
  background-color: color-mix(in srgb, var(--tertiary-bg) 75%, var(--body-color));
}
.button-link-tertiary {
  color: var(--base-tertiary);
}
.button-link-tertiary:hover {
  color: color-mix(in srgb, var(--base-tertiary) 80%, var(--body-color));
}
.button-outlined-success {
  color: var(--base-success);
}
.button-filled-success,
.button-fab-success {
  background-color: var(--success-bg);
  color: var(--body-bg);
}
.button-filled-success:hover,
.button-fab-success:hover {
  background-color: color-mix(in srgb, var(--success-bg) 85%, var(--body-color));
}
.button-filled-success:active,
.button-fab-success:active {
  background-color: color-mix(in srgb, var(--success-bg) 75%, var(--body-color));
}
.button-link-success {
  color: var(--base-success);
}
.button-link-success:hover {
  color: color-mix(in srgb, var(--base-success) 80%, var(--body-color));
}
.button-outlined-info {
  color: var(--base-info);
}
.button-filled-info,
.button-fab-info {
  background-color: var(--info-bg);
  color: var(--body-bg);
}
.button-filled-info:hover,
.button-fab-info:hover {
  background-color: color-mix(in srgb, var(--info-bg) 85%, var(--body-color));
}
.button-filled-info:active,
.button-fab-info:active {
  background-color: color-mix(in srgb, var(--info-bg) 75%, var(--body-color));
}
.button-link-info {
  color: var(--base-info);
}
.button-link-info:hover {
  color: color-mix(in srgb, var(--base-info) 80%, var(--body-color));
}
.button-outlined-warning {
  color: var(--base-warning);
}
.button-filled-warning,
.button-fab-warning {
  background-color: var(--warning-bg);
  color: var(--body-bg);
}
.button-filled-warning:hover,
.button-fab-warning:hover {
  background-color: color-mix(in srgb, var(--warning-bg) 85%, var(--body-color));
}
.button-filled-warning:active,
.button-fab-warning:active {
  background-color: color-mix(in srgb, var(--warning-bg) 75%, var(--body-color));
}
.button-link-warning {
  color: var(--base-warning);
}
.button-link-warning:hover {
  color: color-mix(in srgb, var(--base-warning) 80%, var(--body-color));
}
.button-outlined-danger {
  color: var(--base-danger);
}
.button-filled-danger,
.button-fab-danger {
  background-color: var(--danger-bg);
  color: var(--body-bg);
}
.button-filled-danger:hover,
.button-fab-danger:hover {
  background-color: color-mix(in srgb, var(--danger-bg) 85%, var(--body-color));
}
.button-filled-danger:active,
.button-fab-danger:active {
  background-color: color-mix(in srgb, var(--danger-bg) 75%, var(--body-color));
}
.button-link-danger {
  color: var(--base-danger);
}
.button-link-danger:hover {
  color: color-mix(in srgb, var(--base-danger) 80%, var(--body-color));
}
.button-close {
  min-block-size: auto;
  padding: var(--space-1);
  opacity: 0.5;
  border: 0;
  background: transparent;
}
.button-close:hover {
  opacity: 0.75;
  background: transparent;
}
.button-close:active {
  opacity: 1;
  background: transparent;
}
.button-close > .graphic {
  width: calc(var(--space-base) * 2);
  height: calc(var(--space-base) * 2);
  font-size: calc(var(--space-base) * 2);
}
.button-collapse {
  min-block-size: auto;
  padding: var(--space-1);
  border: 0;
  background: transparent;
}
.button-collapse > .graphic {
  width: calc(var(--space-base) * 2.5);
  height: calc(var(--space-base) * 2.5);
  font-size: calc(var(--space-base) * 2.5);
  transition: transform var(--animation-duration) var(--animation-ease);
}
.button-collapse:hover {
  background: color-mix(in srgb, currentcolor 8%, transparent);
}
.button-collapse[aria-expanded=true] > .graphic {
  transform: rotate(180deg);
}
.button.placement-top,
.button.placement-bottom {
  flex-direction: column;
}
.button[aria-pressed=true] {
  background-color: color-mix(in srgb, currentcolor 15%, transparent);
}
.button[aria-busy=true] {
  pointer-events: none;
  font-size: 0;
  position: relative;
}
.button[aria-busy=true] > .graphic {
  opacity: 0;
}
.button[aria-busy=true]::after {
  content: "";
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  inline-size: calc(var(--space-base) * 2);
  block-size: calc(var(--space-base) * 2);
  margin-block-start: calc(var(--space-base) * -1);
  margin-inline-start: calc(var(--space-base) * -1);
  border: var(--border-width) solid currentcolor;
  border-inline-end-color: transparent;
  border-radius: 50%;
  animation: neo-spin 0.6s linear infinite;
}
.button.button-fab[aria-busy=true]::after {
  inline-size: calc(var(--space-base) * 3);
  block-size: calc(var(--space-base) * 3);
  margin-block-start: calc(var(--space-base) * -1.5);
  margin-inline-start: calc(var(--space-base) * -1.5);
}
.button-group {
  display: inline-flex;
  border-radius: var(--border-radius);
}
.button-group > .button {
  border-radius: 0;
}
.button-group > .button:hover,
.button-group > .button:focus-visible {
  z-index: 1;
}
.button-group > [aria-pressed=true] {
  z-index: 1;
  background-color: color-mix(in srgb, currentcolor 12%, transparent);
}
.button-group > :first-child {
  border-start-start-radius: inherit;
  border-end-start-radius: inherit;
}
.button-group > :last-child {
  border-start-end-radius: inherit;
  border-end-end-radius: inherit;
}
.button-group > .button + .button {
  margin-inline-start: calc(var(--border-width) * -1);
}
.button-group:has(> .button-link) {
  border: var(--border-width) solid currentcolor;
}
.button-group > .button-fab {
  border-radius: var(--border-radius);
}
.button-group-vertical {
  display: inline-flex;
  border-radius: var(--border-radius);
  flex-direction: column;
}
.button-group-vertical > .button {
  border-radius: 0;
  inline-size: 100%;
}
.button-group-vertical > .button:hover,
.button-group-vertical > .button:focus-visible {
  z-index: 1;
}
.button-group-vertical > [aria-pressed=true] {
  z-index: 1;
  background-color: color-mix(in srgb, currentcolor 12%, transparent);
}
.button-group-vertical > :first-child {
  border-start-start-radius: inherit;
  border-start-end-radius: inherit;
}
.button-group-vertical > :last-child {
  border-end-start-radius: inherit;
  border-end-end-radius: inherit;
}
.button-group-vertical > .button + .button {
  margin-block-start: calc(var(--border-width) * -1);
}
.button-group-sm > .button,
.button-group-vertical-sm > .button {
  min-block-size: calc(var(--space-base) * 4);
  padding-block: var(--space-1);
  padding-inline: var(--space-2);
  font-size: calc(var(--space-base) * 1.5);
}
.button-group-lg > .button,
.button-group-vertical-lg > .button {
  min-block-size: calc(var(--space-base) * 6);
  padding-block: var(--space-2);
  padding-inline: var(--space-4);
  font-size: calc(var(--space-base) * 2);
}
.button-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: var(--space-2);
}
.card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-inline-size: 0;
  overflow-wrap: break-word;
  background-color: var(--body-bg);
  background-clip: border-box;
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
}
.card-body {
  flex: 1 1 auto;
  padding: var(--space-3) var(--space-4);
}
.card-title {
  margin-block-end: var(--space-2);
}
.card-subtitle {
  margin-block-start: calc(-0.5 * var(--space-2));
  margin-block-end: 0;
}
.card-text:last-child {
  margin-block-end: 0;
}
.card-header,
.card-footer {
  padding: var(--space-2) var(--space-4);
  background-color: color-mix(in srgb, var(--body-color) 3%, var(--body-bg));
}
.card-header {
  border-block-end: var(--border-width) solid var(--body-color);
}
.card-header:first-child {
  border-start-start-radius: calc(var(--border-radius) - var(--border-width));
  border-start-end-radius: calc(var(--border-radius) - var(--border-width));
}
.card-footer {
  border-block-start: var(--border-width) solid var(--body-color);
}
.card-img,
.card-img-top,
.card-img-bottom {
  inline-size: 100%;
}
.card-img,
.card-img-top {
  border-start-start-radius: calc(var(--border-radius) - var(--border-width));
  border-start-end-radius: calc(var(--border-radius) - var(--border-width));
}
.card-img-bottom {
  border-end-start-radius: calc(var(--border-radius) - var(--border-width));
  border-end-end-radius: calc(var(--border-radius) - var(--border-width));
}
.card-img-overlay {
  position: absolute;
  inset: 0;
  padding: var(--space-4);
  border-radius: calc(var(--border-radius) - var(--border-width));
}
.card-group {
  display: flex;
  flex-flow: row wrap;
}
.card-group > .card {
  flex: 1 0 0%;
  margin-block-end: 0;
}
.card-group > .card:not(:last-child) {
  border-end-end-radius: 0;
  border-start-end-radius: 0;
}
.card-group > .card:not(:first-child) {
  border-end-start-radius: 0;
  border-start-start-radius: 0;
}
.clearfix::after {
  display: block;
  clear: both;
  content: "";
}
.clipboard {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  cursor: pointer;
  transition: color var(--animation-duration) var(--animation-ease), opacity var(--animation-duration) var(--animation-ease);
}
.clipboard:hover {
  color: var(--base-primary);
}
.clipboard-favorite {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  cursor: pointer;
  color: inherit;
  transition: color var(--animation-duration) var(--animation-ease), transform var(--animation-duration) var(--animation-ease);
}
.clipboard-favorite:hover {
  color: var(--warning-color);
}
.clipboard-favorite[aria-pressed=true] {
  color: var(--warning-color);
}
.clipboard-favorite:active {
  transform: scale(0.9);
}
.clipboard-recents {
  list-style: none;
  padding: 0;
  margin: 0;
}
.clipboard-recent-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  cursor: pointer;
  transition: background-color var(--animation-duration) var(--animation-ease);
}
.clipboard-recent-item:hover {
  background-color: color-mix(in srgb, var(--body-color) 5%, var(--body-bg));
}
.clipboard-recent-item .clipboard-recent-time {
  margin-inline-start: auto;
  font-size: 0.75em;
  color: color-mix(in srgb, var(--body-color) 50%, transparent);
}
.code-block {
  overflow: hidden;
  border-radius: var(--border-radius);
}
.code-block-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--border-radius);
}
pre {
  display: block;
  overflow: auto;
}
a > code {
  color: inherit;
}
/* ── Highlight.js theme via Visual Studio palette ── */
.hljs {
  --hljs-color: #000000;
  --hljs-keyword: #0000ff;
  --hljs-string: #a31515;
  --hljs-comment: #008000;
  --hljs-number: #098658;
  --hljs-tag: #800000;
  --hljs-name: #001080;
  --hljs-type: #2b91af;
  --hljs-function: #795e26;
  color: var(--hljs-color);
}
.hljs-keyword,
.hljs-selector-tag,
.hljs-selector-pseudo,
.hljs-selector-id,
.hljs-selector-class {
  color: var(--hljs-keyword);
}
.hljs-string,
.hljs-attr,
.hljs-template-variable {
  color: var(--hljs-string);
}
.hljs-comment,
.hljs-quote {
  color: var(--hljs-comment);
  font-style: italic;
}
.hljs-number,
.hljs-literal,
.hljs-variable,
.hljs-regexp {
  color: var(--hljs-number);
}
.hljs-tag,
.hljs-built_in,
.hljs-builtin-name {
  color: var(--hljs-tag);
}
.hljs-name,
.hljs-attribute,
.hljs-property {
  color: var(--hljs-name);
}
.hljs-type,
.hljs-class,
.hljs-title.class_ {
  color: var(--hljs-type);
}
.hljs-title,
.hljs-title.function_,
.hljs-function .hljs-title {
  color: var(--hljs-function);
}
.container,
.container-content,
.container-fluid {
  width: 100%;
  margin-inline: auto;
  padding: var(--space-3);
}
.container {
  max-width: calc(95% - 5% * (100vw - 20rem) / 70rem);
}
.container-content {
  max-width: calc(85% - 5% * (100vw - 20rem) / 70rem);
}
.container-fluid {
  max-width: 100%;
  padding: var(--space-2);
}
.expander-toggle {
  display: none;
}
/* Flex Direction */
.flex-row {
  flex-direction: row;
}
.flex-column {
  flex-direction: column;
}
.flex-row-reverse {
  flex-direction: row-reverse;
}
.flex-column-reverse {
  flex-direction: column-reverse;
}
/* Flex Wrap */
.flex-wrap {
  flex-wrap: wrap;
}
.flex-nowrap {
  flex-wrap: nowrap;
}
.flex-wrap-reverse {
  flex-wrap: wrap-reverse;
}
/* Flex Gap */
.gap-1 {
  gap: var(--space-1);
}
.gap-h-1 {
  column-gap: var(--space-1);
}
.gap-v-1 {
  row-gap: var(--space-1);
}
.gap-2 {
  gap: var(--space-2);
}
.gap-h-2 {
  column-gap: var(--space-2);
}
.gap-v-2 {
  row-gap: var(--space-2);
}
.gap-3 {
  gap: var(--space-3);
}
.gap-h-3 {
  column-gap: var(--space-3);
}
.gap-v-3 {
  row-gap: var(--space-3);
}
.gap-4 {
  gap: var(--space-4);
}
.gap-h-4 {
  column-gap: var(--space-4);
}
.gap-v-4 {
  row-gap: var(--space-4);
}
.gap-5 {
  gap: var(--space-5);
}
.gap-h-5 {
  column-gap: var(--space-5);
}
.gap-v-5 {
  row-gap: var(--space-5);
}
/* Justify and align content */
.justify-content-start {
  justify-content: start;
}
.align-content-start {
  align-content: start;
}
.justify-content-end {
  justify-content: end;
}
.align-content-end {
  align-content: end;
}
.justify-content-center {
  justify-content: center;
}
.align-content-center {
  align-content: center;
}
.justify-content-between {
  justify-content: space-between;
}
.align-content-between {
  align-content: space-between;
}
.justify-content-around {
  justify-content: space-around;
}
.align-content-around {
  align-content: space-around;
}
.justify-content-evenly {
  justify-content: space-evenly;
}
.align-content-evenly {
  align-content: space-evenly;
}
/* Align items and self */
.align-items-start {
  align-items: start;
}
.align-self-start {
  align-self: start;
}
.align-items-end {
  align-items: end;
}
.align-self-end {
  align-self: end;
}
.align-items-center {
  align-items: center;
}
.align-self-center {
  align-self: center;
}
/* Flex item sizing */
.flex-fill {
  flex: 1 1 auto;
}
.flex-grow-0 {
  flex-grow: 0;
}
.flex-grow-1 {
  flex-grow: 1;
}
.flex-shrink-0 {
  flex-shrink: 0;
}
.flex-shrink-1 {
  flex-shrink: 1;
}
/* Item order */
.order-first {
  order: -1;
}
.order-0 {
  order: 0;
}
.order-1 {
  order: 1;
}
.order-2 {
  order: 2;
}
.order-3 {
  order: 3;
}
.order-4 {
  order: 4;
}
.order-last {
  order: 5;
}
/* Responsive order */
.graphic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  vertical-align: middle;
  color: currentColor;
  flex-shrink: 0;
  width: calc(var(--space-base) * 2);
  height: calc(var(--space-base) * 2);
  font-size: calc(var(--space-base) * 2);
}
.graphic-svg {
  width: 100%;
  height: 100%;
}
.graphic-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: inherit;
}
.graphic-standard {
  width: calc(var(--space-base) * 3);
  height: calc(var(--space-base) * 3);
  font-size: calc(var(--space-base) * 3);
}
.graphic-emphasis {
  width: calc(var(--space-base) * 4);
  height: calc(var(--space-base) * 4);
  font-size: calc(var(--space-base) * 4);
}
.graphic-feature {
  width: calc(var(--space-base) * 6);
  height: calc(var(--space-base) * 6);
  font-size: calc(var(--space-base) * 6);
}
.grid2 {
  display: grid;
  gap: var(--space-3);
  width: 100%;
  grid-template-columns: 1fr;
}
.grid2 > * {
  min-width: 0;
}
.grid-tiles {
  display: grid;
  gap: var(--space-3);
  width: 100%;
  grid-template-columns: repeat(2, 1fr);
}
.grid-tiles > * {
  min-width: 0;
}
.grid-cards {
  display: grid;
  gap: var(--space-3);
  width: 100%;
  grid-template-columns: 1fr;
}
.grid-cards > * {
  min-width: 0;
}
.grid-trios {
  display: grid;
  gap: var(--space-3);
  width: 100%;
  grid-template-columns: 1fr;
}
.grid-trios > * {
  min-width: 0;
}
.grid-sidebar {
  display: grid;
  gap: var(--space-3);
  width: 100%;
  grid-template-columns: 1fr;
}
.grid-sidebar > * {
  min-width: 0;
}
.grid-sidebar-end {
  display: grid;
  gap: var(--space-3);
  width: 100%;
  grid-template-columns: 1fr;
}
.grid-sidebar-end > * {
  min-width: 0;
}
.grid-bento {
  display: grid;
  gap: var(--space-3);
  width: 100%;
  grid-template-columns: 1fr;
}
.grid-bento > * {
  min-width: 0;
  grid-column: 1;
}
.grid-masonry {
  display: block;
  width: 100%;
  columns: 1;
  column-gap: var(--space-3);
}
.grid-masonry > * {
  break-inside: avoid;
  margin-block-end: var(--space-3);
}
a {
  color: color-mix(in srgb, var(--base-primary) 80%, var(--body-color));
}
a:hover {
  color: color-mix(in srgb, var(--base-primary) 10%, var(--body-color));
}
a:not([href]):not([class]), a:not([href]):not([class]):hover {
  color: inherit;
}
.link-primary {
  color: var(--base-primary) !important;
}
.link-primary:hover, .link-primary:focus {
  color: color-mix(in srgb, var(--base-primary) 80%, var(--body-color)) !important;
}
.link-secondary {
  color: var(--base-secondary) !important;
}
.link-secondary:hover, .link-secondary:focus {
  color: color-mix(in srgb, var(--base-secondary) 80%, var(--body-color)) !important;
}
.link-tertiary {
  color: var(--base-tertiary) !important;
}
.link-tertiary:hover, .link-tertiary:focus {
  color: color-mix(in srgb, var(--base-tertiary) 80%, var(--body-color)) !important;
}
.link-success {
  color: var(--base-success) !important;
}
.link-success:hover, .link-success:focus {
  color: color-mix(in srgb, var(--base-success) 80%, var(--body-color)) !important;
}
.link-info {
  color: var(--base-info) !important;
}
.link-info:hover, .link-info:focus {
  color: color-mix(in srgb, var(--base-info) 80%, var(--body-color)) !important;
}
.link-warning {
  color: var(--base-warning) !important;
}
.link-warning:hover, .link-warning:focus {
  color: color-mix(in srgb, var(--base-warning) 80%, var(--body-color)) !important;
}
.link-danger {
  color: var(--base-danger) !important;
}
.link-danger:hover, .link-danger:focus {
  color: color-mix(in srgb, var(--base-danger) 80%, var(--body-color)) !important;
}
.link-body {
  color: var(--body-color) !important;
}
.link-body:hover, .link-body:focus {
  color: color-mix(in srgb, var(--body-color) 80%, var(--body-color)) !important;
}
.link-surface-primary {
  color: var(--surface-primary-color) !important;
}
.link-surface-primary:hover, .link-surface-primary:focus {
  color: color-mix(in srgb, var(--surface-primary-color) 80%, var(--body-color)) !important;
}
.link-surface-secondary {
  color: var(--surface-secondary-color) !important;
}
.link-surface-secondary:hover, .link-surface-secondary:focus {
  color: color-mix(in srgb, var(--surface-secondary-color) 80%, var(--body-color)) !important;
}
.icon-link {
  display: inline-flex;
  gap: 0.375rem;
  align-items: center;
  align-self: start;
}
.icon-link > .graphic {
  flex-shrink: 0;
  transition: transform var(--animation-duration) var(--animation-ease);
}
.icon-link:hover > .graphic, .icon-link:focus-visible > .graphic {
  transform: translate3d(0.25em, 0, 0);
}
.icon-link-hover:hover > .graphic,
.icon-link-hover:focus-visible > .graphic {
  transform: translate3d(0.25em, 0, 0);
}
.skip-link {
  position: fixed;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: 9999;
  padding: var(--space-2) var(--space-4);
  background-color: var(--base-primary);
  color: var(--body-bg);
  font-weight: 600;
  text-decoration: none;
  transform: translateY(-100%);
}
.skip-link:focus {
  transform: translateY(0);
  outline: 2px solid var(--base-primary);
  outline-offset: 2px;
}
.iframe {
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius);
  border: var(--border-width) solid var(--body-color);
}
.iframe iframe {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  border: 0;
}
.img-fluid {
  max-inline-size: 100%;
  block-size: auto;
}
.img-thumbnail {
  max-inline-size: 100%;
  block-size: auto;
  padding: var(--space-1);
  background-color: var(--body-bg);
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
}
.jumbotron {
  padding-block: var(--space-5);
  padding-inline: var(--space-4);
  border-radius: var(--border-radius);
  background-color: var(--surface-primary-bg);
}
.jumbotron-fluid {
  padding-inline: 0;
  border-radius: 0;
}
.jumbotron-title {
  font-size: clamp(1.75rem, 4vw, 3rem);
  font-weight: 700;
  line-height: 1.2;
  margin-block-end: var(--space-3);
}
.jumbotron-lead {
  font-size: clamp(1rem, 2vw, 1.25rem);
  font-weight: 300;
  color: color-mix(in srgb, var(--body-color) 75%, transparent);
  margin-block-end: var(--space-4);
  max-inline-size: 40rem;
}
.list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  list-style: none;
  padding-inline-start: 0;
  margin-block: var(--space-3);
}
.list > li {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--border-radius);
  transition: background-color var(--animation-duration) var(--animation-ease), color var(--animation-duration) var(--animation-ease), border-color var(--animation-duration) var(--animation-ease);
}
.list > li[aria-selected=true] {
  z-index: 1;
  color: var(--body-bg);
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}
.list > li[aria-disabled=true] {
  opacity: 0.38;
  pointer-events: none;
}
.list-group {
  gap: 0;
  border-radius: var(--border-radius);
}
.list-group > li {
  border-radius: 0;
  border: var(--border-width) solid color-mix(in srgb, var(--body-color) 20%, transparent);
}
.list-group > li + li {
  margin-block-start: calc(-1 * var(--border-width));
}
.list-group > li:first-child {
  border-start-start-radius: inherit;
  border-start-end-radius: inherit;
}
.list-group > li:last-child {
  border-end-start-radius: inherit;
  border-end-end-radius: inherit;
}
.list-flush {
  gap: 0;
}
.list-flush > li {
  border-radius: 0;
  border-block-end: var(--border-width) solid color-mix(in srgb, var(--body-color) 20%, transparent);
}
.list-flush > li:last-child {
  border-block-end: 0;
}
.list-action {
  cursor: pointer;
  box-shadow: inset 0 0 0 100vmax transparent;
  transition: background-color var(--animation-duration) var(--animation-ease), color var(--animation-duration) var(--animation-ease), border-color var(--animation-duration) var(--animation-ease), box-shadow var(--animation-duration) var(--animation-ease);
}
.list-action:hover, .list-action:focus-visible {
  z-index: 1;
  box-shadow: inset 0 0 0 100vmax color-mix(in srgb, var(--body-color) 8%, transparent);
}
.list-action:active {
  box-shadow: inset 0 0 0 100vmax color-mix(in srgb, var(--body-color) 12%, transparent);
}
.list-action:focus-visible {
  outline: 0;
  box-shadow: inset 0 0 0 100vmax color-mix(in srgb, var(--body-color) 8%, transparent), 0 0 0 var(--border-width) var(--primary-color);
}
.pagination {
  display: flex;
  padding-inline-start: 0;
  list-style: none;
}
.page-link {
  position: relative;
  display: block;
  padding-block: var(--space-1);
  padding-inline: var(--space-2);
  color: var(--base-primary);
  background-color: var(--body-bg);
  border: var(--border-width) solid var(--body-color);
  text-decoration: none;
  cursor: pointer;
  transition: color var(--animation-duration) var(--animation-ease), background-color var(--animation-duration) var(--animation-ease), border-color var(--animation-duration) var(--animation-ease);
}
.page-link:hover {
  color: color-mix(in srgb, var(--base-primary) 80%, var(--body-color));
  background-color: color-mix(in srgb, var(--body-color) 5%, var(--body-bg));
}
.page-link:focus-visible {
  z-index: 3;
  outline: 0;
  box-shadow: 0 0 0 var(--border-width) color-mix(in srgb, var(--base-primary) 25%, transparent);
}
.page-item.active .page-link, .page-item[aria-current=page] .page-link {
  z-index: 3;
  color: var(--body-bg);
  background-color: var(--base-primary);
  border-color: var(--base-primary);
}
.page-item.disabled .page-link, .page-item[aria-disabled=true] .page-link {
  color: color-mix(in srgb, var(--body-color) 50%, transparent);
  pointer-events: none;
  background-color: var(--body-bg);
}
.placeholder {
  display: inline-block;
  min-block-size: 1em;
  vertical-align: middle;
  cursor: wait;
  background-color: currentcolor;
  opacity: 0.5;
}
.placeholder-xs {
  min-block-size: 0.6em;
}
.placeholder-sm {
  min-block-size: 0.8em;
}
.placeholder-lg {
  min-block-size: 1.2em;
}
.placeholder-glow .placeholder {
  animation: placeholder-glow 2s ease-in-out infinite;
}
@keyframes placeholder-glow {
  50% {
    opacity: 0.2;
  }
}
.placeholder-wave .placeholder {
  mask-image: linear-gradient(130deg, currentcolor 55%, color-mix(in srgb, currentcolor 80%, transparent) 75%, currentcolor 95%);
  mask-size: 200% 100%;
  animation: placeholder-wave 2s linear infinite;
}
@keyframes placeholder-wave {
  100% {
    mask-position: -200% 0%;
  }
}
.progress, progress {
  display: flex;
  block-size: calc(var(--space-base) * 2);
  overflow: hidden;
  font-size: calc(var(--space-base) * 1.5);
  background-color: color-mix(in srgb, var(--body-color) 12%, transparent);
  border-radius: var(--border-radius);
  appearance: none;
  border: none;
}
meter {
  display: flex;
  block-size: calc(var(--space-base) * 2);
  overflow: hidden;
  background-color: color-mix(in srgb, var(--body-color) 12%, transparent);
  border-radius: var(--border-radius);
  appearance: none;
  border: none;
  inline-size: 100%;
}
.progress-bar {
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  color: var(--body-bg);
  text-align: center;
  white-space: nowrap;
  background-color: var(--base-primary);
  transition: width var(--animation-duration) var(--animation-ease);
}
.progress-striped .progress-bar {
  background-image: linear-gradient(45deg, color-mix(in srgb, var(--body-bg) 15%, transparent) 25%, transparent 25%, transparent 50%, color-mix(in srgb, var(--body-bg) 15%, transparent) 50%, color-mix(in srgb, var(--body-bg) 15%, transparent) 75%, transparent 75%, transparent);
  background-size: calc(var(--space-base) * 2) calc(var(--space-base) * 2);
}
@keyframes progress-bar-stripes {
  0% {
    background-position-x: calc(var(--space-base) * 2);
  }
}
.progress-animated .progress-bar {
  animation: progress-bar-stripes 1s linear infinite;
}
.progress-primary .progress-bar {
  background-color: var(--primary-bg);
}
.progress-secondary .progress-bar {
  background-color: var(--secondary-bg);
}
.progress-tertiary .progress-bar {
  background-color: var(--tertiary-bg);
}
.progress-success .progress-bar {
  background-color: var(--success-bg);
}
.progress-info .progress-bar {
  background-color: var(--info-bg);
}
.progress-warning .progress-bar {
  background-color: var(--warning-bg);
}
.progress-danger .progress-bar {
  background-color: var(--danger-bg);
}
.progress-stacked {
  display: flex;
}
.progress-stacked > .progress {
  overflow: visible;
  flex-grow: 0;
  background-color: transparent;
  border-radius: 0;
}
.progress-stacked > .progress:first-child {
  border-start-start-radius: var(--border-radius);
  border-end-start-radius: var(--border-radius);
}
.progress-stacked > .progress:last-child {
  border-start-end-radius: var(--border-radius);
  border-end-end-radius: var(--border-radius);
}
.ribbon {
  position: absolute;
  z-index: 1;
  overflow: hidden;
  inline-size: 5rem;
  block-size: 5rem;
  pointer-events: none;
}
.ribbon span {
  display: block;
  inline-size: 7rem;
  padding-block: var(--space-1);
  font-size: 0.8125em;
  font-weight: 600;
  color: var(--body-bg);
  text-align: center;
  position: absolute;
  box-shadow: 0 0 0.5rem 0 color-mix(in srgb, var(--body-color) 15%, transparent);
}
.ribbon-start {
  inset-block-start: -0.3125rem;
  inset-inline-start: -0.3125rem;
}
.ribbon-start span {
  inset-block-start: 1.1875rem;
  inset-inline-start: -1.3125rem;
  transform: rotate(-45deg);
}
.ribbon-end {
  inset-block-start: -0.3125rem;
  inset-inline-end: -0.3125rem;
}
.ribbon-end span {
  inset-block-start: 1.1875rem;
  inset-inline-end: -1.3125rem;
  transform: rotate(45deg);
}
.ribbon-primary span {
  background-color: var(--base-primary);
}
.ribbon-primary span::before, .ribbon-primary span::after {
  content: "";
  position: absolute;
  inset-block-start: 100%;
  border: 0.1875rem solid transparent;
}
.ribbon-primary span::before {
  inset-inline-start: 0;
  border-inline-start-color: color-mix(in srgb, var(--base-primary) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-primary) 70%, var(--body-color));
}
.ribbon-primary span::after {
  inset-inline-end: 0;
  border-inline-end-color: color-mix(in srgb, var(--base-primary) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-primary) 70%, var(--body-color));
}
.ribbon-secondary span {
  background-color: var(--base-secondary);
}
.ribbon-secondary span::before, .ribbon-secondary span::after {
  content: "";
  position: absolute;
  inset-block-start: 100%;
  border: 0.1875rem solid transparent;
}
.ribbon-secondary span::before {
  inset-inline-start: 0;
  border-inline-start-color: color-mix(in srgb, var(--base-secondary) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-secondary) 70%, var(--body-color));
}
.ribbon-secondary span::after {
  inset-inline-end: 0;
  border-inline-end-color: color-mix(in srgb, var(--base-secondary) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-secondary) 70%, var(--body-color));
}
.ribbon-tertiary span {
  background-color: var(--base-tertiary);
}
.ribbon-tertiary span::before, .ribbon-tertiary span::after {
  content: "";
  position: absolute;
  inset-block-start: 100%;
  border: 0.1875rem solid transparent;
}
.ribbon-tertiary span::before {
  inset-inline-start: 0;
  border-inline-start-color: color-mix(in srgb, var(--base-tertiary) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-tertiary) 70%, var(--body-color));
}
.ribbon-tertiary span::after {
  inset-inline-end: 0;
  border-inline-end-color: color-mix(in srgb, var(--base-tertiary) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-tertiary) 70%, var(--body-color));
}
.ribbon-success span {
  background-color: var(--base-success);
}
.ribbon-success span::before, .ribbon-success span::after {
  content: "";
  position: absolute;
  inset-block-start: 100%;
  border: 0.1875rem solid transparent;
}
.ribbon-success span::before {
  inset-inline-start: 0;
  border-inline-start-color: color-mix(in srgb, var(--base-success) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-success) 70%, var(--body-color));
}
.ribbon-success span::after {
  inset-inline-end: 0;
  border-inline-end-color: color-mix(in srgb, var(--base-success) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-success) 70%, var(--body-color));
}
.ribbon-info span {
  background-color: var(--base-info);
}
.ribbon-info span::before, .ribbon-info span::after {
  content: "";
  position: absolute;
  inset-block-start: 100%;
  border: 0.1875rem solid transparent;
}
.ribbon-info span::before {
  inset-inline-start: 0;
  border-inline-start-color: color-mix(in srgb, var(--base-info) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-info) 70%, var(--body-color));
}
.ribbon-info span::after {
  inset-inline-end: 0;
  border-inline-end-color: color-mix(in srgb, var(--base-info) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-info) 70%, var(--body-color));
}
.ribbon-warning span {
  background-color: var(--base-warning);
}
.ribbon-warning span::before, .ribbon-warning span::after {
  content: "";
  position: absolute;
  inset-block-start: 100%;
  border: 0.1875rem solid transparent;
}
.ribbon-warning span::before {
  inset-inline-start: 0;
  border-inline-start-color: color-mix(in srgb, var(--base-warning) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-warning) 70%, var(--body-color));
}
.ribbon-warning span::after {
  inset-inline-end: 0;
  border-inline-end-color: color-mix(in srgb, var(--base-warning) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-warning) 70%, var(--body-color));
}
.ribbon-danger span {
  background-color: var(--base-danger);
}
.ribbon-danger span::before, .ribbon-danger span::after {
  content: "";
  position: absolute;
  inset-block-start: 100%;
  border: 0.1875rem solid transparent;
}
.ribbon-danger span::before {
  inset-inline-start: 0;
  border-inline-start-color: color-mix(in srgb, var(--base-danger) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-danger) 70%, var(--body-color));
}
.ribbon-danger span::after {
  inset-inline-end: 0;
  border-inline-end-color: color-mix(in srgb, var(--base-danger) 70%, var(--body-color));
  border-block-start-color: color-mix(in srgb, var(--base-danger) 70%, var(--body-color));
}
.section, section, article {
  margin-block-end: var(--space-4);
}
.vr {
  display: inline-block;
  align-self: stretch;
  inline-size: 1px;
  min-block-size: 1em;
  background-color: currentcolor;
  opacity: 0.25;
}
hr {
  margin-block: var(--space-3);
  margin-inline: 0;
  color: inherit;
  border: 0;
  border-block-start: var(--border-width) solid;
  opacity: 0.25;
}
.spinner {
  display: inline-block;
  inline-size: 2rem;
  block-size: 2rem;
  vertical-align: text-bottom;
  border: 0.25em solid currentcolor;
  border-inline-end-color: transparent;
  border-radius: 50%;
  animation: neo-spin 0.75s linear infinite;
}
.spinner-grow {
  display: inline-block;
  inline-size: 2rem;
  block-size: 2rem;
  vertical-align: text-bottom;
  background-color: currentcolor;
  border-radius: 50%;
  opacity: 0;
  animation: spinner-pulse 0.75s linear infinite;
}
.spinner-sm {
  inline-size: 1rem;
  block-size: 1rem;
}
.spinner.spinner-sm {
  border-width: 0.2em;
}
.spinner-primary,
.spinner-grow.spinner-primary {
  color: var(--primary-color);
}
.spinner-secondary,
.spinner-grow.spinner-secondary {
  color: var(--secondary-color);
}
.spinner-tertiary,
.spinner-grow.spinner-tertiary {
  color: var(--tertiary-color);
}
.spinner-success,
.spinner-grow.spinner-success {
  color: var(--success-color);
}
.spinner-info,
.spinner-grow.spinner-info {
  color: var(--info-color);
}
.spinner-warning,
.spinner-grow.spinner-warning {
  color: var(--warning-color);
}
.spinner-danger,
.spinner-grow.spinner-danger {
  color: var(--danger-color);
}
.autosave {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: 0.875em;
  color: color-mix(in srgb, var(--body-color) 65%, transparent);
}
.autosave .spinner,
.autosave .spinner-grow {
  inline-size: 1rem;
  block-size: 1rem;
}
.autosave .spinner {
  border-width: 0.2em;
}
.autosave-saved {
  color: var(--success-color);
}
.autosave-error {
  color: var(--danger-color);
}
@keyframes spinner-pulse {
  0% {
    transform: scale(0);
  }
  50% {
    opacity: 1;
    transform: none;
  }
}
.hstack {
  display: flex;
  flex-direction: row;
  align-items: center;
  align-self: stretch;
}
.hstack .vr {
  align-self: stretch;
  inline-size: 1px;
}
.vstack {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  align-self: stretch;
}
.table, table {
  inline-size: 100%;
  margin-block-end: var(--space-3);
  vertical-align: top;
  border-color: var(--body-color);
  color: var(--body-color);
  border-collapse: collapse;
}
.table > :not(caption) > * > *, table > :not(caption) > * > * {
  padding: var(--space-2);
  border-block-end-width: var(--border-width);
}
.table > tbody, table > tbody {
  vertical-align: inherit;
}
.table > thead, table > thead {
  vertical-align: bottom;
}
.table > tfoot, table > tfoot {
  vertical-align: bottom;
  font-weight: 500;
}
.table > caption, table > caption {
  padding-block: var(--space-2);
  color: color-mix(in srgb, var(--body-color) 65%, transparent);
  caption-side: bottom;
}
caption {
  padding-block: var(--space-2);
  color: color-mix(in srgb, var(--body-color) 65%, transparent);
  caption-side: bottom;
}
col, colgroup {
  background: transparent;
}
tfoot {
  vertical-align: bottom;
  font-weight: 500;
}
.table-striped > tbody > tr:nth-of-type(odd) > * {
  background-color: color-mix(in srgb, var(--body-color) 5%, transparent);
}
.table-hover > tbody > tr:hover > * {
  background-color: color-mix(in srgb, var(--body-color) 7.5%, transparent);
}
.table-bordered > :not(caption) > * > * {
  border-width: var(--border-width);
}
.table-borderless > :not(caption) > * > * {
  border-block-end-width: 0;
}
.table-sm > :not(caption) > * > * {
  padding: var(--space-1);
}
.table-responsive-scroll {
  overflow-x: auto;
}
.tile {
  position: relative;
}
.tile .text-eyebrow {
  display: block;
  margin-bottom: var(--space-2);
}
.tile-catalog {
  position: relative;
  overflow: hidden;
  text-align: center;
}
.tile-catalog a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  color: inherit;
}
.timeline {
  position: relative;
  padding-inline-start: 2rem;
}
.timeline::before {
  content: "";
  position: absolute;
  inset-block-start: 0;
  inset-block-end: 0;
  inset-inline-start: 0.5rem;
  inline-size: 2px;
  background-color: var(--body-color);
}
.timeline-item {
  position: relative;
  padding-block-end: var(--space-4);
}
.timeline-icon {
  position: absolute;
  inset-inline-start: -1.75rem;
  inset-block-start: 0;
  inline-size: 1.5rem;
  block-size: 1.5rem;
  border-radius: 50%;
  background-color: var(--body-color);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
.timeline-icon .graphic {
  color: var(--body-color);
}
.timeline-content {
  background-color: var(--surface-primary-bg);
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
  padding: var(--space-3);
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.timeline-date {
  font-size: 0.875em;
  color: color-mix(in srgb, var(--body-color) 65%, transparent);
  margin-block-end: var(--space-1);
}
.timeline-primary .timeline-icon {
  background-color: var(--base-primary);
}
.timeline-primary .timeline-icon .graphic {
  color: var(--body-bg);
}
.timeline-secondary .timeline-icon {
  background-color: var(--base-secondary);
}
.timeline-secondary .timeline-icon .graphic {
  color: var(--body-bg);
}
.timeline-success .timeline-icon {
  background-color: var(--base-success);
}
.timeline-success .timeline-icon .graphic {
  color: var(--body-bg);
}
.timeline-info .timeline-icon {
  background-color: var(--base-info);
}
.timeline-info .timeline-icon .graphic {
  color: var(--body-bg);
}
.timeline-warning .timeline-icon {
  background-color: var(--base-warning);
}
.timeline-warning .timeline-icon .graphic {
  color: var(--body-bg);
}
.timeline-danger .timeline-icon {
  background-color: var(--base-danger);
}
.timeline-danger .timeline-icon .graphic {
  color: var(--body-bg);
}
.timeline-activity .timeline-item {
  padding-block-end: var(--space-2);
}
.timeline-activity .timeline-content {
  padding: var(--space-2) var(--space-3);
  border: none;
  box-shadow: none;
  background-color: transparent;
}
.timeline-activity .timeline-actor {
  font-weight: 600;
}
.timeline-activity .timeline-action {
  color: color-mix(in srgb, var(--body-color) 65%, transparent);
  font-size: 0.875em;
}
.timeline-activity .timeline-timestamp {
  color: color-mix(in srgb, var(--body-color) 50%, transparent);
  font-size: 0.75em;
}
.timeline-activity .timeline-icon {
  inline-size: 1rem;
  block-size: 1rem;
  inset-inline-start: -1.25rem;
}
p {
  margin-block-end: var(--space-2);
}
blockquote {
  display: block;
}
blockquote::before {
  content: "- ";
}
label {
  font-size: 1.25rem;
  display: inline-block;
}
small {
  font-size: 0.875rem;
}
strong {
  font-weight: bolder;
}
b {
  font-weight: bold;
}
mark {
  padding: 0.1875rem;
  background-color: var(--warning-bg);
}
abbr[title] {
  text-decoration: underline dotted;
  cursor: help;
  text-decoration-skip-ink: none;
}
sub {
  font-size: 0.875rem;
}
output {
  font-family: var(--font-code);
}
samp {
  font-family: var(--font-code);
}
kbd {
  font-size: 0.875em;
  padding: 0.1875rem 0.375rem;
  color: var(--body-bg);
  background-color: var(--body-color);
  border-radius: var(--border-radius);
}
.text-lead {
  font-size: 1.25rem;
  font-weight: 300;
  display: block;
  margin-block: var(--space-2);
}
.text-initialism {
  font-size: 0.875em;
  text-transform: uppercase;
}
.text-italic {
  font-style: italic;
}
.text-reset {
  color: inherit;
}
.text-muted {
  color: color(from currentColor srgb r g b/0.5);
}
.text-eyebrow {
  font-size: 0.8rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.text-body {
  color: var(--body-color);
}
.text-surface-primary {
  color: var(--surface-primary-color);
}
.text-surface-secondary {
  color: var(--surface-secondary-color);
}
.text-primary {
  color: var(--primary-color);
}
.text-secondary {
  color: var(--secondary-color);
}
.text-tertiary {
  color: var(--tertiary-color);
}
.text-success {
  color: var(--success-color);
}
.text-info {
  color: var(--info-color);
}
.text-warning {
  color: var(--warning-color);
}
.text-danger {
  color: var(--danger-color);
}
.text-lighter {
  font-weight: 300;
}
.text-light {
  font-weight: 500;
}
.text-bold {
  font-weight: 700;
}
.text-bolder {
  font-weight: 900;
}
.lh-sm {
  line-height: 1;
}
.lh-md {
  line-height: 1.25;
}
.lh-base {
  line-height: 1.5;
}
.lh-lg {
  line-height: 2;
}
.text-decoration-underline {
  text-decoration: underline;
}
.text-decoration-line-through {
  text-decoration: line-through;
}
.text-lowercase {
  text-transform: lowercase;
}
.text-uppercase {
  text-transform: uppercase;
}
.text-capitalize {
  text-transform: capitalize;
}
.user-select-all {
  user-select: all;
}
.user-select-none {
  user-select: none;
}
.text-start {
  text-align: start;
}
.text-center {
  text-align: center;
}
.text-end {
  text-align: end;
}
/* Wrap & Truncate */
.text-wrap {
  white-space: normal;
  overflow-wrap: break-word;
  word-break: break-word;
}
.text-nowrap {
  white-space: nowrap;
  overflow: visible;
  text-overflow: clip;
}
.text-truncate {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-3 {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-4 {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-5 {
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-6 {
  display: -webkit-box;
  -webkit-line-clamp: 6;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.text-title {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  max-width: 100%;
}
.footer-body {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
}
.footer-brand p {
  margin-block-start: var(--space-1);
}
.footer-featured {
  margin-block-start: var(--space-2);
}
.footer-contact {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.footer-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding-block-start: var(--space-3);
  margin-block-start: var(--space-3);
  border-block-start: var(--border-width) solid color-mix(in srgb, currentcolor 12%, transparent);
}
.footer, footer {
  padding: var(--space-3);
}
.footer-compact {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding: var(--space-3);
}
.footer-collapse {
  padding: var(--space-3);
}
.footer-collapse-panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--animation-duration) var(--animation-ease);
}
.footer-collapse-panel > * {
  overflow: hidden;
  min-block-size: 0;
}
.footer-collapse:has([aria-expanded=true]) .footer-collapse-panel {
  grid-template-rows: 1fr;
}
.footer-collapse .footer-bar {
  margin-block-start: 0;
  border-block-start: 0;
  opacity: 1;
}
.footer-collapse:has([aria-expanded=true]) .footer-bar {
  margin-block-start: var(--space-3);
  border-block-start: var(--border-width) solid color-mix(in srgb, currentcolor 12%, transparent);
}
.header, header {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
}
.header-item {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  flex: 1;
  padding: var(--space-2);
  text-decoration: none;
  color: inherit;
  border-radius: var(--border-radius);
  transition: background var(--animation-duration) var(--animation-ease);
}
.header-item::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: currentcolor;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.97);
  transition: opacity calc(var(--animation-duration) * 2) var(--animation-ease), transform calc(var(--animation-duration) * 2) var(--animation-ease);
}
.header-item:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.1;
  transform: scale(1);
  transition: none;
}
.header-item:hover, .header-item:focus-visible {
  background: color-mix(in srgb, currentColor 6%, transparent);
}
.header-item.active {
  color: var(--primary-color);
}
.header-item-icon {
  width: calc(var(--space-base) * 3);
  height: calc(var(--space-base) * 3);
  font-size: calc(var(--space-base) * 3);
}
.header-item-label {
  display: none;
  font-size: 0.75rem;
}
/* --- Layout container ------------------------------------- */
.layout {
  --_layout-zone-margin: 0px;
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}
.layout-header {
  border-block-end: var(--border-width) solid color-mix(in srgb, currentcolor 12%, transparent);
}
.layout-navbar {
  position: sticky;
  inset-block-start: 0;
  z-index: 250;
  border-block-end: var(--border-width) solid color-mix(in srgb, currentcolor 12%, transparent);
}
/* --- Phone - consolidate bottom bar ----------------------- */
.layout-brand {
  display: flex;
  align-items: center;
  text-decoration: none;
  color: inherit;
  gap: var(--space-2);
}
.layout-brand h3 {
  margin: 0;
  font-size: 1.5rem;
}
.layout-brand img {
  height: calc(var(--space-base) * 5);
  width: auto;
  transition: height var(--animation-duration) var(--animation-ease);
}
/* --- Main ------------------------------------------------- */
.layout-main {
  min-height: calc(100dvh - var(--layout-navbar-height));
}
/* --- Scroll snap ------------------------------------------ */
.layout-article.scroll-snap {
  overflow-y: auto;
  scroll-snap-type: y mandatory;
}
.layout-article.scroll-snap > * {
  scroll-snap-align: start;
}
/* --- Sidebar ---------------------------------------------- */
.layout-sidebar {
  position: fixed;
  inset-block: 0;
  inset-inline-start: 0;
  z-index: 450;
  width: 18rem;
  border-inline-end: var(--border-width) solid color-mix(in srgb, currentcolor 12%, transparent);
  white-space: nowrap;
  background: var(--surface-primary-bg);
  display: none;
}
.layout-sidebar:not([aria-hidden=true]) {
  display: block;
  --_enter-distance: 0.625rem;
  animation: neo-slide-inline-start var(--animation-duration) var(--animation-ease);
}
/* --- Sidebar drawer header --------------------------------- */
.layout-sidebar-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3);
}
/* --- Footer ----------------------------------------------- */
.layout-footer {
  display: none;
  border-block-start: var(--border-width) solid color-mix(in srgb, currentcolor 12%, transparent);
}
#goTopButton {
  position: fixed;
  inset-block-end: var(--space-4);
  inset-inline-end: var(--space-4);
  z-index: 251;
  display: none;
  opacity: 0;
  transition: opacity var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
/* --- Tablet ----------------------------------------------- */
/* --- Laptop ----------------------------------------------- */
/**************************************/
/* errors */
/**************************************/
#blazor-error-ui {
  background: var(--danger-bg);
  color: var(--danger-color-tone, #fff);
  padding: var(--space-3);
  display: none;
  position: fixed;
  inset-block-end: 0;
  inset-inline: 0;
  width: 100%;
  z-index: 1000;
}
#blazor-error-ui .reload {
  color: var(--danger-color-tone, #fff);
}
#blazor-error-ui .dismiss {
  cursor: pointer;
}
.blazor-error-boundary {
  background: var(--danger-bg);
  color: var(--danger-color-tone, #fff);
  padding: var(--space-3);
  margin-block: var(--space-4);
}
.blazor-error-boundary::after {
  content: "Sorry, a rotten gremlin got us!";
}
/* --- Surface: Material ------------------------------------ */
/* --- Surface: Neo ----------------------------------------- */
/* Suppress motion on initial render - must be last to win by source order.
   JS removes this class after setting the initial aria-hidden state. */
.layout-sidebar.no-transition {
  transition: none;
  animation: none;
}
.navbar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-inline: var(--space-3);
  padding: var(--space-4) var(--space-3);
  transition: padding var(--animation-duration) var(--animation-ease);
}
.navbar.shrink {
  padding: var(--space-3);
}
.navbar img {
  height: calc(var(--space-base) * 5);
  width: auto;
}
.navbar-collapse {
  flex: 1;
  display: flex;
  align-items: center;
}
[aria-controls=navbar-collapse] {
  display: none;
}
.navbar-menu {
  display: flex;
  justify-content: center;
}
.navbar-actions {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  margin-inline-start: auto;
}
/* Phone: navbar hidden, collapse panel anchored above header */
/* Tablet: navbar at top - panel drops below */
/* ── Surface: Material ────────────────────────────────────────── */
.sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-1);
  overflow-y: auto;
  height: 100%;
}
.sidebar img {
  height: calc(var(--space-base) * 5);
  width: auto;
}
.accordion {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
  overflow: hidden;
}
.accordion-item {
  border-block-end: var(--border-width) solid var(--body-color);
}
.accordion-item:last-child {
  border-block-end: none;
}
.accordion-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  inline-size: 100%;
  padding: var(--space-3) var(--space-4);
  border: none;
  background: none;
  color: var(--body-color);
  font: inherit;
  font-weight: 600;
  cursor: pointer;
  text-align: start;
  transition: background-color var(--animation-duration) var(--animation-ease);
}
.accordion-trigger:hover {
  background-color: color-mix(in srgb, var(--body-color) 5%, var(--body-bg));
}
.accordion-panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--animation-duration) var(--animation-ease);
}
[aria-expanded=true] + .accordion-panel {
  grid-template-rows: 1fr;
}
.accordion-panel-inner {
  overflow: hidden;
}
.accordion-body {
  padding: var(--space-3) var(--space-4);
  padding-block-start: 0;
}
.accordion-flush {
  border: none;
  border-radius: 0;
}
.accordion-flush .accordion-item {
  border-inline: none;
}
.accordion-flush .accordion-item:first-child {
  border-block-start: none;
}
.accordion-flush .accordion-item:last-child {
  border-block-end: none;
}
.carousel {
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius);
}
.carousel-track {
  display: flex;
  transition: transform var(--animation-duration) var(--animation-ease);
}
.carousel-slide {
  flex: 0 0 100%;
  min-inline-size: 0;
}
.carousel-slide img {
  display: block;
  inline-size: 100%;
  block-size: auto;
  object-fit: cover;
}
.carousel-control {
  position: absolute;
  inset-block-start: 50%;
  transform: translateY(-50%);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 2.5rem;
  block-size: 2.5rem;
  border: none;
  border-radius: 50%;
  background-color: color-mix(in srgb, var(--body-bg) 80%, transparent);
  color: var(--body-color);
  cursor: pointer;
  transition: background-color var(--animation-duration) var(--animation-ease);
}
.carousel-control:hover {
  background-color: var(--body-bg);
}
.carousel-prev {
  inset-inline-start: var(--space-2);
}
.carousel-next {
  inset-inline-end: var(--space-2);
}
.carousel-indicators {
  position: absolute;
  inset-block-end: var(--space-2);
  inset-inline: 0;
  display: flex;
  justify-content: center;
  gap: var(--space-1);
  z-index: 2;
}
.carousel-indicator {
  inline-size: 0.5rem;
  block-size: 0.5rem;
  border-radius: 50%;
  border: none;
  padding: 0;
  background-color: color-mix(in srgb, var(--body-bg) 50%, transparent);
  cursor: pointer;
  transition: background-color var(--animation-duration) var(--animation-ease);
}
.carousel-indicator[aria-current=true], .carousel-indicator.active {
  background-color: var(--body-bg);
}
.curtain {
  display: flex;
  position: relative;
  block-size: 100dvh;
  align-items: stretch;
  justify-content: center;
}
.curtain-panel {
  flex-basis: 33.33%;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-position: center;
  background-size: cover;
  transition: flex-basis calc(var(--animation-duration) * 3) var(--animation-ease);
}
.curtain-panel:hover {
  flex-basis: 50%;
}
.curtain-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--body-color) 40%, transparent);
  transition: background-color calc(var(--animation-duration) * 3) var(--animation-ease);
}
.curtain-panel:hover::after {
  background: color-mix(in srgb, var(--body-bg) 60%, transparent);
}
.curtain-title {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  z-index: 2;
  transform: translate(-50%, -50%);
  pointer-events: none;
  font-weight: 600;
  text-align: center;
  opacity: 1;
  transition: transform var(--animation-duration) var(--animation-ease), opacity var(--animation-duration) var(--animation-ease);
}
.curtain-panel:hover .curtain-title {
  transform: translate(-50%, -70%);
  opacity: 0;
}
.curtain-content {
  z-index: 1;
  opacity: 0;
  transform: translateY(var(--space-2));
  transition: opacity var(--animation-duration) var(--animation-ease), transform var(--animation-duration) var(--animation-ease);
}
.curtain-panel:hover .curtain-content {
  opacity: 1;
  transform: translateY(0);
}
.data-chart {
  position: relative;
  inline-size: 100%;
}
.data-chart canvas {
  inline-size: 100%;
  block-size: auto;
}
.data-chart-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  min-block-size: 16rem;
  border: var(--border-width) dashed var(--body-color);
  border-radius: var(--border-radius);
  color: color-mix(in srgb, var(--body-color) 40%, transparent);
  font-size: 0.875em;
}
.data-grid {
  inline-size: 100%;
  overflow-x: auto;
}
.data-grid-table {
  inline-size: 100%;
  border-collapse: collapse;
  font-size: 0.875em;
}
.data-grid-table th {
  padding: var(--space-2) var(--space-3);
  text-align: start;
  font-weight: 600;
  color: color-mix(in srgb, var(--body-color) 75%, transparent);
  border-block-end: 2px solid var(--body-color);
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
  transition: color var(--animation-duration) var(--animation-ease);
}
.data-grid-table th:hover {
  color: var(--body-color);
}
.data-grid-table td {
  padding: var(--space-2) var(--space-3);
  border-block-end: var(--border-width) solid var(--body-color);
  vertical-align: middle;
}
.data-grid-table tbody tr {
  transition: background-color var(--animation-duration) var(--animation-ease);
}
.data-grid-table tbody tr:hover {
  background-color: color-mix(in srgb, var(--body-color) 3%, var(--body-bg));
}
.data-grid-sort {
  display: inline-flex;
  margin-inline-start: var(--space-1);
  opacity: 0.4;
}
.data-grid-sort.active {
  opacity: 1;
  color: var(--base-primary);
}
.data-grid-sort.desc {
  transform: rotate(180deg);
}
.data-grid-striped tbody tr:nth-child(even) {
  background-color: color-mix(in srgb, var(--body-color) 2%, var(--body-bg));
}
.data-grid-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: var(--space-2);
  font-size: 0.875em;
  color: color-mix(in srgb, var(--body-color) 65%, transparent);
}
/* ── Accent color map ─────────────────────────────────────────── */
/* ── Drawer panel (toggled via aria-hidden) ──────────────────── */
.drawer {
  position: fixed;
  z-index: 450;
  background: var(--surface-primary-bg);
  border-inline-start: 1px solid var(--surface-secondary-bg);
  box-shadow: 0 var(--elevation-size-3) calc(var(--elevation-size-3) * 2) color-mix(in srgb, var(--body-color) var(--elevation-mix-3), transparent);
  overflow-y: auto;
}
/* ── Side variants ────────────────────────────────────────────── */
.drawer-right {
  inset-block: 0;
  inset-inline-end: 0;
  width: 26.25rem;
  border-inline-start: 1px solid var(--surface-secondary-bg);
  border-inline-end: none;
  --_slide-x: calc(var(--dir) * 100%);
  --_slide-y: 0;
  display: none;
  translate: var(--_slide-x) var(--_slide-y);
  transition: translate var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
.drawer-right:not([aria-hidden=true]) {
  display: block;
  translate: 0 0;
}
@starting-style {
  .drawer-right:not([aria-hidden=true]) {
    translate: var(--_slide-x) var(--_slide-y);
  }
}
.drawer-left {
  inset-block: 0;
  inset-inline-start: 0;
  width: 26.25rem;
  border-inline-start: none;
  border-inline-end: 1px solid var(--surface-secondary-bg);
  --_slide-x: calc(var(--dir) * 100% * -1);
  --_slide-y: 0;
  display: none;
  translate: var(--_slide-x) var(--_slide-y);
  transition: translate var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
.drawer-left:not([aria-hidden=true]) {
  display: block;
  translate: 0 0;
}
@starting-style {
  .drawer-left:not([aria-hidden=true]) {
    translate: var(--_slide-x) var(--_slide-y);
  }
}
.drawer-bottom {
  inset-inline: 0;
  inset-block-end: 0;
  width: 100%;
  max-height: 75vh;
  border-block-start: 1px solid var(--surface-secondary-bg);
  border-inline: none;
  border-radius: var(--border-radius) var(--border-radius) 0 0;
  --_slide-x: 0;
  --_slide-y: 100%;
  display: none;
  translate: var(--_slide-x) var(--_slide-y);
  transition: translate var(--animation-duration) var(--animation-ease), display var(--animation-duration) allow-discrete;
}
.drawer-bottom:not([aria-hidden=true]) {
  display: block;
  translate: 0 0;
}
@starting-style {
  .drawer-bottom:not([aria-hidden=true]) {
    translate: var(--_slide-x) var(--_slide-y);
  }
}
/* ── Phone: full width for side drawers ───────────────────────── */
/* ── Inner structure ──────────────────────────────────────────── */
.drawer-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  position: relative;
}
.drawer-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4) var(--space-2);
}
.drawer-head-left {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.drawer-eyebrow {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--surface-secondary-color);
}
.drawer-title {
  font-size: 1.25rem;
  font-weight: 500;
}
.drawer-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(var(--space-base) * 5);
  height: calc(var(--space-base) * 5);
  border: none;
  background: var(--surface-secondary-bg);
  border-radius: var(--border-radius);
  cursor: pointer;
  font-size: 0.875rem;
  color: inherit;
  flex-shrink: 0;
  transition: background var(--animation-duration) var(--animation-ease);
}
.drawer-close:hover {
  background: color-mix(in srgb, var(--body-color) 15%, transparent);
}
.drawer-close:focus-visible {
  outline: var(--border-width) solid currentcolor;
  outline-offset: var(--space-1);
  box-shadow: none;
}
.drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-2) var(--space-4) var(--space-4);
}
/* ── Accent stripe (::before on .drawer-inner) ────────────────── */
.drawer-accent-primary .drawer-inner::before {
  content: "";
  display: block;
  height: 0.1875rem;
  background: var(--base-primary);
  flex-shrink: 0;
}
.drawer-accent-secondary .drawer-inner::before {
  content: "";
  display: block;
  height: 0.1875rem;
  background: var(--base-secondary);
  flex-shrink: 0;
}
.drawer-accent-tertiary .drawer-inner::before {
  content: "";
  display: block;
  height: 0.1875rem;
  background: var(--base-tertiary);
  flex-shrink: 0;
}
.drawer-accent-info .drawer-inner::before {
  content: "";
  display: block;
  height: 0.1875rem;
  background: var(--base-info);
  flex-shrink: 0;
}
/* ── Neo surface glass effect ─────────────────────────────────── */
/* ================================================================
   TOGGLE DRAWER BUTTON
   ================================================================ */
.toggle-drawer {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--surface-secondary-bg);
  border-radius: var(--border-radius);
  background: none;
  font: inherit;
  color: inherit;
  cursor: pointer;
  transition: background var(--animation-duration) var(--animation-ease), border-color var(--animation-duration) var(--animation-ease);
}
.toggle-drawer:hover {
  background: var(--surface-secondary-bg);
}
.toggle-drawer:focus-visible {
  outline: var(--border-width) solid currentcolor;
  outline-offset: var(--space-1);
  box-shadow: none;
}
.toggle-drawer[disabled] {
  opacity: 0.5;
  pointer-events: none;
}
.toggle-drawer-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: var(--border-radius);
  background: var(--surface-secondary-bg);
  font-size: 0.875rem;
}
.toggle-drawer-label {
  font-size: 0.8125rem;
}
/* ── Toggle accent variants ───────────────────────────────────── */
.toggle-drawer.drawer-accent-primary {
  border-color: var(--base-primary);
}
.toggle-drawer.drawer-accent-primary:hover {
  background: color-mix(in srgb, var(--base-primary) 10%, transparent);
}
.toggle-drawer.drawer-accent-primary .toggle-drawer-icon {
  background: color-mix(in srgb, var(--base-primary) 15%, transparent);
  color: var(--base-primary);
}
.toggle-drawer.drawer-accent-secondary {
  border-color: var(--base-secondary);
}
.toggle-drawer.drawer-accent-secondary:hover {
  background: color-mix(in srgb, var(--base-secondary) 10%, transparent);
}
.toggle-drawer.drawer-accent-secondary .toggle-drawer-icon {
  background: color-mix(in srgb, var(--base-secondary) 15%, transparent);
  color: var(--base-secondary);
}
.toggle-drawer.drawer-accent-tertiary {
  border-color: var(--base-tertiary);
}
.toggle-drawer.drawer-accent-tertiary:hover {
  background: color-mix(in srgb, var(--base-tertiary) 10%, transparent);
}
.toggle-drawer.drawer-accent-tertiary .toggle-drawer-icon {
  background: color-mix(in srgb, var(--base-tertiary) 15%, transparent);
  color: var(--base-tertiary);
}
.toggle-drawer.drawer-accent-info {
  border-color: var(--base-info);
}
.toggle-drawer.drawer-accent-info:hover {
  background: color-mix(in srgb, var(--base-info) 10%, transparent);
}
.toggle-drawer.drawer-accent-info .toggle-drawer-icon {
  background: color-mix(in srgb, var(--base-info) 15%, transparent);
  color: var(--base-info);
}
.map, map {
  position: relative;
  inline-size: 100%;
  min-block-size: 20rem;
  border-radius: var(--border-radius);
  overflow: hidden;
  background-color: color-mix(in srgb, var(--body-color) 5%, var(--body-bg));
}
.map-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 100%;
  min-block-size: 20rem;
  border: var(--border-width) dashed var(--body-color);
  border-radius: var(--border-radius);
  color: color-mix(in srgb, var(--body-color) 40%, transparent);
  font-size: 0.875em;
}
/* ── Component constants ─────────────────────────────────────────── */
/* ── Floating panel mixin (avoids @extend inside @media) ──────── */
/* ── Base reset ───────────────────────────────────────────────── */
.menu, menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
/* ── Menu link (shared across all variants) ───────────────────── */
.menu-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  inline-size: 100%;
  border: none;
  background: none;
  font: inherit;
  color: inherit;
  cursor: pointer;
  text-align: start;
  text-decoration: none;
  white-space: nowrap;
  border-radius: var(--border-radius);
  position: relative;
  overflow: hidden;
  transition: background var(--animation-duration) var(--animation-ease), color var(--animation-duration) var(--animation-ease);
}
.menu-link::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: currentcolor;
  pointer-events: none;
  opacity: 0;
  transform: scale(0.97);
  transition: opacity calc(var(--animation-duration) * 2) var(--animation-ease), transform calc(var(--animation-duration) * 2) var(--animation-ease);
}
.menu-link:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.1;
  transform: scale(1);
  transition: none;
}
.menu-link:hover {
  background: var(--surface-secondary-bg);
}
.menu-link:active {
  background: color-mix(in srgb, currentcolor 12%, transparent);
}
.menu-link:focus-visible {
  outline: var(--border-width) solid currentcolor;
  outline-offset: var(--space-1);
  box-shadow: none;
}
/* ── Inner elements ───────────────────────────────────────────── */
.menu-icon {
  flex-shrink: 0;
  inline-size: 1.125rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.menu-text {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
}
.menu-abbr {
  display: none;
  font-size: 0.625rem;
  text-transform: uppercase;
  line-height: 1;
}
/* Menu chevron: atom handles sizing + rotation, menu overrides font-size */
.menu .chevron {
  font-size: 0.75rem;
}
.menu-header {
  padding: var(--space-1) var(--space-3);
  font-size: 0.75rem;
  text-transform: uppercase;
  color: var(--surface-secondary-color);
}
/* ── Group open state (aria-expanded is the single source of truth) ── */
.menu-link[aria-expanded=true] {
  color: var(--primary-color);
}
/* ── Active route (Blazor NavLink) ────────────────────────────── */
.menu-link.active {
  background: color-mix(in srgb, var(--primary-color) 10%, transparent);
  color: var(--primary-color);
}
.menu-link.active .menu-icon,
.menu-link.active .chevron {
  color: var(--primary-color);
}
/* ── Active depth indicator for nested vertical items ─────────── */
.menu-collapse .menu-link.active {
  border-inline-start: 2px solid var(--primary-color);
}
/* ── Disabled ─────────────────────────────────────────────────── */
.menu-link[disabled],
.menu-link[aria-disabled=true] {
  opacity: 0.5;
  pointer-events: none;
}
/* ================================================================
   VERTICAL
   Accordion submenus via grid-template-rows animation.
   ================================================================ */
.menu-vertical {
  display: flex;
  flex-direction: column;
}
.menu-vertical .menu-collapse {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--animation-duration) var(--animation-ease);
}
.menu-vertical .menu-collapse > * {
  overflow: hidden;
  min-block-size: 0;
}
.menu-vertical .menu-collapse > ul {
  list-style: none;
  margin: 0;
  padding: 0;
  padding-inline-start: var(--space-3);
}
.menu-vertical .menu-link[aria-expanded=true] + .menu-collapse {
  grid-template-rows: 1fr;
}
/* ================================================================
   HORIZONTAL
   Row of items with floating dropdown panels below.
   ================================================================ */
.menu-horizontal {
  display: flex;
  align-items: stretch;
  flex: 1;
}
.menu-horizontal > .menu-item {
  display: flex;
  align-items: stretch;
}
.menu-horizontal > .menu-item > .menu-link {
  display: flex;
  align-items: center;
  inline-size: auto;
}
.menu-horizontal .menu-group {
  position: relative;
}
.menu-horizontal .menu-group > .menu-collapse {
  display: none;
  position: absolute;
  inset-block-start: 100%;
  inset-inline-start: 0;
  min-inline-size: 15rem;
  inline-size: max-content;
  white-space: nowrap;
  background: var(--surface-primary-bg);
  border: 1px solid var(--surface-secondary-bg);
  border-radius: var(--border-radius);
  box-shadow: 0 var(--elevation-size-2) calc(var(--elevation-size-2) * 2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  z-index: 100;
}
.menu-horizontal .menu-group > .menu-collapse > ul {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  max-block-size: 50dvh;
  padding: var(--space-1);
  list-style: none;
  margin: 0;
}
.menu-horizontal .menu-link[aria-expanded=true] + .menu-collapse {
  display: block;
  --_enter-distance: 0.625rem;
  animation: neo-slide-down var(--animation-duration) var(--animation-ease);
}
/* Nested flyout: appears to the side of the parent panel */
.menu-horizontal .menu-collapse .menu-group > .menu-collapse {
  inset-block-start: 0;
  inset-inline-start: 100%;
}
/* ================================================================
   DROPDOWN
   Floating panel revealed by a trigger button.
   aria-expanded on the trigger is the single source of truth.
   ================================================================ */
.menu-dropdown-wrapper {
  position: relative;
  display: inline-block;
}
.menu-dropdown {
  display: none;
  position: absolute;
  inset-block-start: 100%;
  inset-inline-start: 0;
  min-inline-size: 15rem;
  inline-size: max-content;
  white-space: nowrap;
  background: var(--surface-primary-bg);
  border: 1px solid var(--surface-secondary-bg);
  border-radius: var(--border-radius);
  box-shadow: 0 var(--elevation-size-2) calc(var(--elevation-size-2) * 2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  z-index: 100;
  padding: var(--space-1);
}
.menu-dropdown-wrapper > .menu-link[aria-expanded=true] + .menu-dropdown {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  max-block-size: 50dvh;
  --_enter-distance: 0.625rem;
  animation: neo-slide-down var(--animation-duration) var(--animation-ease);
}
/* Accordion groups inside dropdown */
.menu-dropdown .menu-collapse {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows var(--animation-duration) var(--animation-ease);
}
.menu-dropdown .menu-collapse > * {
  overflow: hidden;
  min-block-size: 0;
}
.menu-dropdown .menu-collapse > ul {
  list-style: none;
  margin: 0;
  padding: 0;
  padding-inline-start: var(--space-3);
}
.menu-dropdown .menu-link[aria-expanded=true] + .menu-collapse {
  grid-template-rows: 1fr;
}
/* ================================================================
   RESPONSIVE
   Add data-responsive to opt into viewport-aware mode switching.

   Vertical:   tablet = compact icons + flyout groups
   Horizontal: laptop-down = vertical accordion
   Dropdown:   phone = bottom sheet with backdrop
   ================================================================ */
/* ── Vertical responsive: compact icons at tablet ────────────── */
/* ── Horizontal responsive: vertical accordion when collapsed ── */
/* ── Dropdown responsive: bottom sheet at phone ──────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: color-mix(in srgb, var(--body-color) 50%, transparent);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--animation-duration) var(--animation-ease);
}
.modal-overlay:not([aria-hidden=true]) {
  opacity: 1;
  pointer-events: auto;
}
.modal {
  position: relative;
  display: flex;
  flex-direction: column;
  inline-size: min(100vw - var(--space-4) * 2, 32rem);
  max-block-size: calc(100vh - var(--space-4) * 2);
  background-color: var(--body-bg);
  border-radius: var(--border-radius);
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--body-color) var(--elevation-mix-3), transparent);
  transform: scale(0.95) translateY(1rem);
  transition: transform var(--animation-duration) var(--animation-ease), opacity var(--animation-duration) var(--animation-ease);
}
:not([aria-hidden=true]) > .modal {
  transform: scale(1) translateY(0);
}
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-block-end: var(--border-width) solid var(--body-color);
}
.modal-header h2, .modal-header h3, .modal-header h4 {
  margin: 0;
  font-size: 1.125rem;
}
.modal-body {
  flex: 1;
  padding: var(--space-4);
  overflow-y: auto;
}
.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-block-start: var(--border-width) solid var(--body-color);
}
.modal-sm {
  inline-size: min(100vw - var(--space-4) * 2, 20rem);
}
.modal-lg {
  inline-size: min(100vw - var(--space-4) * 2, 48rem);
}
.modal-xl {
  inline-size: min(100vw - var(--space-4) * 2, 64rem);
}
.modal-fullscreen {
  inline-size: 100vw;
  max-block-size: 100vh;
  border-radius: 0;
  margin: 0;
}
.parallax {
  position: relative;
  display: flex;
  min-block-size: 100dvh;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: center/cover no-repeat fixed;
}
.parallax-video {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 120dvh;
  object-fit: cover;
  object-position: center;
  will-change: transform;
}
.parallax-overlay {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 200dvh;
  background: color-mix(in srgb, var(--body-color) 40%, transparent);
}
.parallax-svg svg {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}
.parallax-content {
  position: relative;
  z-index: 1;
}
.parallax-gradient {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
}
.parallax-gradient-animated {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  background: linear-gradient(270deg, var(--base-primary), var(--base-secondary), var(--base-tertiary), var(--base-info), var(--base-danger));
  background-size: 800% 800%;
  animation: parallax-gradient-shift 15s ease infinite;
}
@keyframes parallax-gradient-shift {
  0%, 100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}
.tabs-list {
  display: flex;
  gap: 0;
  border-block-end: 2px solid var(--body-color);
  margin-block-end: var(--space-3);
}
.tabs-list[role=tablist] {
  list-style: none;
  padding: 0;
  margin: 0;
}
.tab {
  padding: var(--space-2) var(--space-4);
  border: none;
  background: none;
  color: color-mix(in srgb, var(--body-color) 65%, transparent);
  font: inherit;
  font-weight: 500;
  cursor: pointer;
  border-block-end: 2px solid transparent;
  margin-block-end: -2px;
  transition: color var(--animation-duration) var(--animation-ease), border-color var(--animation-duration) var(--animation-ease);
}
.tab:hover {
  color: var(--body-color);
}
.tab[aria-selected=true] {
  color: var(--base-primary);
  border-block-end-color: var(--base-primary);
}
.tab:focus-visible {
  outline: 2px solid var(--base-primary);
  outline-offset: -2px;
}
.tabs-pills {
  border-block-end: none;
}
.tabs-pills .tab {
  border-radius: var(--border-radius);
  border-block-end: none;
  margin-block-end: 0;
}
.tabs-pills .tab[aria-selected=true] {
  background-color: var(--base-primary);
  color: var(--body-bg);
}
.tab-panel[hidden] {
  display: none;
}
.toast-container {
  position: fixed;
  z-index: 600;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-3);
  pointer-events: none;
  inset-block-end: 0;
  inset-inline-end: 0;
}
.toast {
  pointer-events: auto;
  min-inline-size: 18rem;
  max-inline-size: 24rem;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--border-radius);
  background-color: var(--body-bg);
  border: var(--border-width) solid var(--body-color);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  animation: toast-in var(--animation-duration) var(--animation-ease);
}
.toast-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-block-end: var(--space-1);
  font-weight: 600;
}
.toast-body {
  font-size: 0.875em;
  color: color-mix(in srgb, var(--body-color) 80%, transparent);
}
.toast-close {
  margin-inline-start: auto;
  padding: 0;
  border: none;
  background: none;
  cursor: pointer;
  color: color-mix(in srgb, var(--body-color) 50%, transparent);
}
.toast-close:hover {
  color: var(--body-color);
}
.toast-dismissing {
  animation: toast-out var(--animation-duration) var(--animation-ease) forwards;
}
.toast-primary {
  border-inline-start: 4px solid var(--base-primary);
}
.toast-secondary {
  border-inline-start: 4px solid var(--base-secondary);
}
.toast-tertiary {
  border-inline-start: 4px solid var(--base-tertiary);
}
.toast-success {
  border-inline-start: 4px solid var(--base-success);
}
.toast-info {
  border-inline-start: 4px solid var(--base-info);
}
.toast-warning {
  border-inline-start: 4px solid var(--base-warning);
}
.toast-danger {
  border-inline-start: 4px solid var(--base-danger);
}
@keyframes toast-in {
  from {
    opacity: 0;
    translate: 1rem 0;
  }
  to {
    opacity: 1;
    translate: 0 0;
  }
}
@keyframes toast-out {
  from {
    opacity: 1;
    translate: 0 0;
  }
  to {
    opacity: 0;
    translate: 1rem 0;
  }
}
.popover-wrapper {
  position: relative;
  display: inline-block;
}
.popover-trigger {
  all: unset;
  cursor: pointer;
  display: inline;
}
.popover {
  position: absolute;
  z-index: 500;
  inset-block-end: calc(100% + 0.5rem);
  inset-inline-start: 50%;
  transform: translateX(-50%);
  min-inline-size: 16rem;
  max-inline-size: 24rem;
  background-color: var(--body-bg);
  border: var(--border-width) solid var(--body-color);
  border-radius: var(--border-radius);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  display: none;
}
[aria-expanded=true] + .popover {
  display: block;
}
.popover-header {
  padding: var(--space-2) var(--space-3);
  font-weight: 600;
  border-block-end: var(--border-width) solid var(--body-color);
}
.popover-body {
  padding: var(--space-2) var(--space-3);
  font-size: 0.875em;
}
.popover-bottom {
  inset-block-end: auto;
  inset-block-start: calc(100% + 0.5rem);
}
.popover-start {
  inset-block-end: auto;
  inset-block-start: 50%;
  inset-inline-start: auto;
  inset-inline-end: calc(100% + 0.5rem);
  transform: translateY(-50%);
}
.popover-end {
  inset-block-end: auto;
  inset-block-start: 50%;
  inset-inline-start: calc(100% + 0.5rem);
  transform: translateY(-50%);
}
[data-tooltip] {
  position: relative;
}
[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  z-index: 700;
  inset-block-end: calc(100% + 0.5rem);
  inset-inline-start: 50%;
  transform: translateX(-50%);
  padding: var(--space-1) var(--space-2);
  font-size: 0.8125em;
  font-weight: 500;
  line-height: 1.4;
  color: var(--body-bg);
  background-color: color-mix(in srgb, var(--body-color) 90%, transparent);
  border-radius: var(--border-radius);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--animation-duration) var(--animation-ease);
}
[data-tooltip]:hover::after, [data-tooltip]:focus-visible::after {
  opacity: 1;
}
[data-tooltip-placement=bottom]::after {
  inset-block-end: auto;
  inset-block-start: calc(100% + 0.5rem);
}
[data-tooltip-placement=start]::after {
  inset-block-end: auto;
  inset-block-start: 50%;
  inset-inline-start: auto;
  inset-inline-end: calc(100% + 0.5rem);
  transform: translateY(-50%);
}
[data-tooltip-placement=end]::after {
  inset-block-end: auto;
  inset-block-start: 50%;
  inset-inline-start: calc(100% + 0.5rem);
  transform: translateY(-50%);
}
.video {
  position: relative;
  inline-size: 100%;
  border-radius: var(--border-radius);
  overflow: hidden;
}
.video iframe,
.video video {
  display: block;
  inline-size: 100%;
  block-size: 100%;
  border: none;
}
.video-16x9 {
  aspect-ratio: 16/9;
}
.video-4x3 {
  aspect-ratio: 4/3;
}
.video-1x1 {
  aspect-ratio: 1/1;
}
.video-21x9 {
  aspect-ratio: 21/9;
}
.wizard-steps {
  display: flex;
  gap: var(--space-1);
  margin-block-end: var(--space-4);
  padding: 0;
  list-style: none;
  counter-reset: step;
}
.wizard-step {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  font-weight: 500;
  color: color-mix(in srgb, var(--body-color) 50%, transparent);
  counter-increment: step;
}
.wizard-step::before {
  content: counter(step);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  inline-size: 1.75rem;
  block-size: 1.75rem;
  border-radius: 50%;
  font-size: 0.875em;
  font-weight: 600;
  background-color: color-mix(in srgb, var(--body-color) 10%, var(--body-bg));
  flex-shrink: 0;
}
.wizard-step[aria-current=step] {
  color: var(--base-primary);
}
.wizard-step[aria-current=step]::before {
  background-color: var(--base-primary);
  color: var(--body-bg);
}
.wizard-step.completed {
  color: var(--base-success);
}
.wizard-step.completed::before {
  background-color: var(--base-success);
  color: var(--body-bg);
}
.wizard-body {
  margin-block-end: var(--space-4);
}
.wizard-actions {
  display: flex;
  justify-content: space-between;
  gap: var(--space-2);
}
:root,
[data-theme=light] {
  color-scheme: light;
  --body-color: #212529;
  --body-bg: #ffffff;
}
[data-theme=dark]{
  color-scheme: dark;
  --body-color: #dee2e6;
  --body-bg: #212529;

.hljs {
  --hljs-color: #d4d4d4;
  --hljs-keyword: #569cd6;
  --hljs-string: #ce9178;
  --hljs-comment: #6a9955;
  --hljs-number: #b5cea8;
  --hljs-tag: #569cd6;
  --hljs-name: #9cdcfe;
  --hljs-type: #4ec9b0;
  --hljs-function: #dcdcaa;
}
}
[data-surface=flat]{
  --border-radius: 0;

.skin-primary, .tone-primary, .emboss-primary {
  color: var(--base-primary);
  background-color: color-mix(in srgb, var(--base-primary) 15%, var(--body-bg));
}

.skin-secondary, .tone-secondary, .emboss-secondary {
  color: var(--base-secondary);
  background-color: color-mix(in srgb, var(--base-secondary) 15%, var(--body-bg));
}

.skin-tertiary, .tone-tertiary, .emboss-tertiary {
  color: var(--base-tertiary);
  background-color: color-mix(in srgb, var(--base-tertiary) 15%, var(--body-bg));
}

.skin-success, .tone-success, .emboss-success {
  color: var(--base-success);
  background-color: color-mix(in srgb, var(--base-success) 15%, var(--body-bg));
}

.skin-info, .tone-info, .emboss-info {
  color: var(--base-info);
  background-color: color-mix(in srgb, var(--base-info) 15%, var(--body-bg));
}

.skin-warning, .tone-warning, .emboss-warning {
  color: var(--base-warning);
  background-color: color-mix(in srgb, var(--base-warning) 15%, var(--body-bg));
}

.skin-danger, .tone-danger, .emboss-danger {
  color: var(--base-danger);
  background-color: color-mix(in srgb, var(--base-danger) 15%, var(--body-bg));
}

.emboss-body {
  box-shadow: none;
}

.emboss-surface-primary {
  box-shadow: none;
}

.emboss-surface-secondary {
  box-shadow: none;
}

.emboss-primary {
  box-shadow: none;
}

.emboss-secondary {
  box-shadow: none;
}

.emboss-tertiary {
  box-shadow: none;
}

.emboss-success {
  box-shadow: none;
}

.emboss-info {
  box-shadow: none;
}

.emboss-warning {
  box-shadow: none;
}

.emboss-danger {
  box-shadow: none;
}

.elevation-body-1 {
  box-shadow: none;
}
.elevation-body-2 {
  box-shadow: none;
}
.elevation-body-3 {
  box-shadow: none;
}
.elevation-surface-primary-1 {
  box-shadow: none;
}
.elevation-surface-primary-2 {
  box-shadow: none;
}
.elevation-surface-primary-3 {
  box-shadow: none;
}
.elevation-surface-secondary-1 {
  box-shadow: none;
}
.elevation-surface-secondary-2 {
  box-shadow: none;
}
.elevation-surface-secondary-3 {
  box-shadow: none;
}
.elevation-primary-1 {
  box-shadow: none;
}
.elevation-primary-2 {
  box-shadow: none;
}
.elevation-primary-3 {
  box-shadow: none;
}
.elevation-secondary-1 {
  box-shadow: none;
}
.elevation-secondary-2 {
  box-shadow: none;
}
.elevation-secondary-3 {
  box-shadow: none;
}
.elevation-tertiary-1 {
  box-shadow: none;
}
.elevation-tertiary-2 {
  box-shadow: none;
}
.elevation-tertiary-3 {
  box-shadow: none;
}
.elevation-success-1 {
  box-shadow: none;
}
.elevation-success-2 {
  box-shadow: none;
}
.elevation-success-3 {
  box-shadow: none;
}
.elevation-info-1 {
  box-shadow: none;
}
.elevation-info-2 {
  box-shadow: none;
}
.elevation-info-3 {
  box-shadow: none;
}
.elevation-warning-1 {
  box-shadow: none;
}
.elevation-warning-2 {
  box-shadow: none;
}
.elevation-warning-3 {
  box-shadow: none;
}
.elevation-danger-1 {
  box-shadow: none;
}
.elevation-danger-2 {
  box-shadow: none;
}
.elevation-danger-3 {
  box-shadow: none;
}
}
[data-surface=material]{
  --elevation-size-1: 0 0.125rem 0.25rem;
  --elevation-size-2: 0 0.25rem 0.5rem;
  --elevation-size-3: 0 0.5rem 1rem;
  --elevation-mix: 20%;
  --elevation-mix-1: 14%;
  --elevation-mix-2: 18%;
  --elevation-mix-3: 22%;
  --font-base: Roboto, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Oxygen, Ubuntu, Cantarell, Open Sans, Helvetica Neue, sans-serif;
  --border-radius: 0.5rem;

.skin-primary, .tone-primary, .emboss-primary {
  color: color-mix(in srgb, var(--base-primary) 60%, var(--body-color));
  background-color: color-mix(in srgb, var(--base-primary) 10%, var(--body-bg));
}

.skin-secondary, .tone-secondary, .emboss-secondary {
  color: color-mix(in srgb, var(--base-secondary) 60%, var(--body-color));
  background-color: color-mix(in srgb, var(--base-secondary) 10%, var(--body-bg));
}

.skin-tertiary, .tone-tertiary, .emboss-tertiary {
  color: color-mix(in srgb, var(--base-tertiary) 60%, var(--body-color));
  background-color: color-mix(in srgb, var(--base-tertiary) 10%, var(--body-bg));
}

.skin-success, .tone-success, .emboss-success {
  color: color-mix(in srgb, var(--base-success) 60%, var(--body-color));
  background-color: color-mix(in srgb, var(--base-success) 10%, var(--body-bg));
}

.skin-info, .tone-info, .emboss-info {
  color: color-mix(in srgb, var(--base-info) 60%, var(--body-color));
  background-color: color-mix(in srgb, var(--base-info) 10%, var(--body-bg));
}

.skin-warning, .tone-warning, .emboss-warning {
  color: color-mix(in srgb, var(--base-warning) 60%, var(--body-color));
  background-color: color-mix(in srgb, var(--base-warning) 10%, var(--body-bg));
}

.skin-danger, .tone-danger, .emboss-danger {
  color: color-mix(in srgb, var(--base-danger) 60%, var(--body-color));
  background-color: color-mix(in srgb, var(--base-danger) 10%, var(--body-bg));
}

.loader-logo {
  filter: drop-shadow(0 0.5rem 1rem color-mix(in srgb, var(--body-color) var(--elevation-mix-3), transparent));
}

.tactile::before {
  border-radius: 50%;
  transform: scale(0);
}
.tactile:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.14;
  transform: scale(2.5);
}

details > summary::before {
  border-radius: 50%;
  transform: scale(0);
}
details > summary:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.14;
  transform: scale(2.5);
}

.button {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.button::before {
  border-radius: 50%;
  transform: scale(0);
}
.button:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.14;
  transform: scale(2.5);
}
.button-filled {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
}
.button-link {
  box-shadow: none;
}
.button-fab {
  border-radius: 50%;
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
}
.button-group {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.button-group > .button {
  box-shadow: none;
}
.button-group > .button-fab {
  border-radius: 50%;
}
.button-group > .button-fab + .button-fab {
  margin-inline-start: calc(var(--space-base) * -1.5);
}

.graphic-svg {
  filter: drop-shadow(0 1px 2px color-mix(in srgb, currentColor 12%, transparent));
}

.list-group {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.header-item::before {
  border-radius: 50%;
  transform: scale(0);
}
.header-item:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.14;
  transform: scale(2.5);
}
.layout-header {
  border-block-end: 0;
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.layout-navbar {
  border-block-end: 0;
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.layout-sidebar {
  border-inline-end: 0;
  box-shadow: 0.125rem 0 0.25rem color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.layout-footer {
  border-block-start: 0;
  box-shadow: 0 -0.125rem 0.25rem color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.menu-link::before {
  border-radius: 50%;
  transform: scale(0);
}
.menu-link:active:not(:disabled):not([aria-disabled=true])::before {
  opacity: 0.14;
  transform: scale(2.5);
}
}
[data-surface=neo]{
  --elevation-size-1: 0 0.125rem 0.25rem;
  --elevation-size-2: 0 0.25rem 0.5rem;
  --elevation-size-3: 0 0.5rem 1rem;
  --elevation-mix: 20%;
  --elevation-mix-1: 14%;
  --elevation-mix-2: 18%;
  --elevation-mix-3: 22%;
  --neo-blur: blur(10px);
  --font-base: Inter, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Oxygen, Ubuntu, Cantarell, Open Sans, Helvetica Neue, sans-serif;
  --body-bg-glass:
      radial-gradient(1200px 600px at 12% 8%, color(from var(--base-primary) srgb r g b/0.22) 0%, transparent 60%),
      radial-gradient(900px 500px at 88% 18%, color(from var(--base-secondary) srgb r g b/0.16) 0%, transparent 58%),
      radial-gradient(1000px 700px at 50% 92%, color(from var(--base-tertiary) srgb r g b/0.14) 0%, transparent 62%);
  --body-bg-neo:
      radial-gradient(circle at 20% 20%, color(from var(--base-primary) srgb r g b/0.22), transparent 28%),
      radial-gradient(circle at 80% 25%, color(from var(--base-secondary) srgb r g b/0.16), transparent 26%),
      radial-gradient(circle at 50% 80%, color(from var(--base-tertiary) srgb r g b/0.14), transparent 24%),
      linear-gradient(
          135deg,
          color-mix(in srgb, var(--body-color) 20%, var(--body-bg)),
          color-mix(in srgb, var(--body-color) 10%, var(--body-bg)) 55%,
          color-mix(in srgb, var(--body-color) 5%, var(--body-bg))
      );
  --border-radius: 0.75rem;

.skin-body, .tone-body, .emboss-body {
  background-color: color(from var(--body-color) srgb r g b/0.03);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.skin-surface-primary, .tone-surface-primary, .emboss-surface-primary {
  background-color: color(from var(--body-color) srgb r g b/0.03);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.skin-surface-secondary, .tone-surface-secondary, .emboss-surface-secondary {
  background-color: color(from var(--body-color) srgb r g b/0.03);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.skin-primary, .tone-primary, .emboss-primary {
  color: var(--base-primary);
  background-color: color(from var(--base-primary) srgb r g b/0.04);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.skin-secondary, .tone-secondary, .emboss-secondary {
  color: var(--base-secondary);
  background-color: color(from var(--base-secondary) srgb r g b/0.04);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.skin-tertiary, .tone-tertiary, .emboss-tertiary {
  color: var(--base-tertiary);
  background-color: color(from var(--base-tertiary) srgb r g b/0.04);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.skin-success, .tone-success, .emboss-success {
  color: var(--base-success);
  background-color: color(from var(--base-success) srgb r g b/0.04);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.skin-info, .tone-info, .emboss-info {
  color: var(--base-info);
  background-color: color(from var(--base-info) srgb r g b/0.04);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.skin-warning, .tone-warning, .emboss-warning {
  color: var(--base-warning);
  background-color: color(from var(--base-warning) srgb r g b/0.04);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.skin-danger, .tone-danger, .emboss-danger {
  color: var(--base-danger);
  background-color: color(from var(--base-danger) srgb r g b/0.04);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.tone-body, .emboss-body {
  border: var(--border-width) solid color-mix(in srgb, var(--body-color) 50%, transparent);
}

.emboss-body {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}

.tone-surface-primary, .emboss-surface-primary {
  border: var(--border-width) solid color-mix(in srgb, var(--surface-primary-color) 50%, transparent);
}

.emboss-surface-primary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--surface-primary-color) var(--elevation-mix-1), transparent);
}

.tone-surface-secondary, .emboss-surface-secondary {
  border: var(--border-width) solid color-mix(in srgb, var(--surface-secondary-color) 50%, transparent);
}

.emboss-surface-secondary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--surface-secondary-color) var(--elevation-mix-1), transparent);
}

.tone-primary, .emboss-primary {
  border: var(--border-width) solid color-mix(in srgb, var(--primary-color) 50%, transparent);
}

.emboss-primary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--primary-color) var(--elevation-mix-1), transparent);
}

.tone-secondary, .emboss-secondary {
  border: var(--border-width) solid color-mix(in srgb, var(--secondary-color) 50%, transparent);
}

.emboss-secondary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--secondary-color) var(--elevation-mix-1), transparent);
}

.tone-tertiary, .emboss-tertiary {
  border: var(--border-width) solid color-mix(in srgb, var(--tertiary-color) 50%, transparent);
}

.emboss-tertiary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--tertiary-color) var(--elevation-mix-1), transparent);
}

.tone-success, .emboss-success {
  border: var(--border-width) solid color-mix(in srgb, var(--success-color) 50%, transparent);
}

.emboss-success {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--success-color) var(--elevation-mix-1), transparent);
}

.tone-info, .emboss-info {
  border: var(--border-width) solid color-mix(in srgb, var(--info-color) 50%, transparent);
}

.emboss-info {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--info-color) var(--elevation-mix-1), transparent);
}

.tone-warning, .emboss-warning {
  border: var(--border-width) solid color-mix(in srgb, var(--warning-color) 50%, transparent);
}

.emboss-warning {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--warning-color) var(--elevation-mix-1), transparent);
}

.tone-danger, .emboss-danger {
  border: var(--border-width) solid color-mix(in srgb, var(--danger-color) 50%, transparent);
}

.emboss-danger {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--danger-color) var(--elevation-mix-1), transparent);
}

body {
  background-image: var(--body-bg-glass);
  background-attachment: fixed;
}
.backdrop {
  backdrop-filter: var(--neo-blur);
}

.border-body {
  border: var(--border-width) solid color-mix(in srgb, var(--body-color) 50%, transparent);
}
.border-surface-primary {
  border: var(--border-width) solid color-mix(in srgb, var(--surface-primary-color) 50%, transparent);
}
.border-surface-secondary {
  border: var(--border-width) solid color-mix(in srgb, var(--surface-secondary-color) 50%, transparent);
}
.border-primary {
  border: var(--border-width) solid color-mix(in srgb, var(--primary-color) 50%, transparent);
}
.border-secondary {
  border: var(--border-width) solid color-mix(in srgb, var(--secondary-color) 50%, transparent);
}
.border-tertiary {
  border: var(--border-width) solid color-mix(in srgb, var(--tertiary-color) 50%, transparent);
}
.border-success {
  border: var(--border-width) solid color-mix(in srgb, var(--success-color) 50%, transparent);
}
.border-info {
  border: var(--border-width) solid color-mix(in srgb, var(--info-color) 50%, transparent);
}
.border-warning {
  border: var(--border-width) solid color-mix(in srgb, var(--warning-color) 50%, transparent);
}
.border-danger {
  border: var(--border-width) solid color-mix(in srgb, var(--danger-color) 50%, transparent);
}

.elevation-body-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.elevation-body-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
}
.elevation-body-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--body-color) var(--elevation-mix-3), transparent);
}
.elevation-surface-primary-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--surface-primary-color) var(--elevation-mix-1), transparent);
}
.elevation-surface-primary-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--surface-primary-color) var(--elevation-mix-2), transparent);
}
.elevation-surface-primary-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--surface-primary-color) var(--elevation-mix-3), transparent);
}
.elevation-surface-secondary-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--surface-secondary-color) var(--elevation-mix-1), transparent);
}
.elevation-surface-secondary-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--surface-secondary-color) var(--elevation-mix-2), transparent);
}
.elevation-surface-secondary-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--surface-secondary-color) var(--elevation-mix-3), transparent);
}
.elevation-primary-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--primary-color) var(--elevation-mix-1), transparent);
}
.elevation-primary-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--primary-color) var(--elevation-mix-2), transparent);
}
.elevation-primary-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--primary-color) var(--elevation-mix-3), transparent);
}
.elevation-secondary-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--secondary-color) var(--elevation-mix-1), transparent);
}
.elevation-secondary-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--secondary-color) var(--elevation-mix-2), transparent);
}
.elevation-secondary-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--secondary-color) var(--elevation-mix-3), transparent);
}
.elevation-tertiary-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--tertiary-color) var(--elevation-mix-1), transparent);
}
.elevation-tertiary-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--tertiary-color) var(--elevation-mix-2), transparent);
}
.elevation-tertiary-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--tertiary-color) var(--elevation-mix-3), transparent);
}
.elevation-success-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--success-color) var(--elevation-mix-1), transparent);
}
.elevation-success-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--success-color) var(--elevation-mix-2), transparent);
}
.elevation-success-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--success-color) var(--elevation-mix-3), transparent);
}
.elevation-info-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--info-color) var(--elevation-mix-1), transparent);
}
.elevation-info-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--info-color) var(--elevation-mix-2), transparent);
}
.elevation-info-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--info-color) var(--elevation-mix-3), transparent);
}
.elevation-warning-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--warning-color) var(--elevation-mix-1), transparent);
}
.elevation-warning-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--warning-color) var(--elevation-mix-2), transparent);
}
.elevation-warning-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--warning-color) var(--elevation-mix-3), transparent);
}
.elevation-danger-1 {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--danger-color) var(--elevation-mix-1), transparent);
}
.elevation-danger-2 {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--danger-color) var(--elevation-mix-2), transparent);
}
.elevation-danger-3 {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--danger-color) var(--elevation-mix-3), transparent);
}

:focus-visible {
  outline-color: var(--primary-color);
}

h1, h2, h3, h4, h5, h6 {
  background: linear-gradient(135deg, var(--base-primary) 0%, var(--base-secondary) 50%, var(--base-tertiary) 100%);
  background-clip: text;
  color: transparent;
}

.loader {
  background-image: var(--body-bg-glass);
  background-attachment: fixed;
}

.loader-logo {
  filter: drop-shadow(0 0.5rem 1.5rem color-mix(in srgb, var(--base-primary) 50%, transparent));
}

.tactile {
  transition: box-shadow var(--animation-duration) var(--animation-ease), translate var(--animation-duration) var(--animation-ease);
}
.tactile::before {
  display: none;
}
.tactile:hover:not(:active):not(:disabled):not([aria-disabled=true]) {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  translate: 0 -2px;
}

details > summary {
  transition: box-shadow var(--animation-duration) var(--animation-ease), translate var(--animation-duration) var(--animation-ease);
}
details > summary::before {
  display: none;
}
details > summary:hover:not(:active):not(:disabled):not([aria-disabled=true]) {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  translate: 0 -2px;
}

figure, .figure {
  box-shadow: var(--elevation-size-3) color-mix(in srgb, currentcolor var(--elevation-mix-3), transparent);
}

.button {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
  transition: box-shadow var(--animation-duration) var(--animation-ease), translate var(--animation-duration) var(--animation-ease);
}
.button::before {
  display: none;
}
.button:hover:not(:active):not(:disabled):not([aria-disabled=true]) {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  translate: 0 -2px;
}
.button-filled {
  background: color(from var(--body-color) srgb r g b/0.12);
  backdrop-filter: var(--neo-blur) saturate(140%);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
}
.button-filled:hover {
  background: color(from var(--body-color) srgb r g b/0.18);
}
.button-filled:active {
  background: color(from var(--body-color) srgb r g b/0.24);
}
.button-link {
  box-shadow: none;
}
.button-fab {
  border-radius: var(--border-radius);
  background: color(from var(--body-color) srgb r g b/0.12);
  backdrop-filter: var(--neo-blur) saturate(140%);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
}
.button-fab:hover {
  background: color(from var(--body-color) srgb r g b/0.18);
}
.button-fab:active {
  background: color(from var(--body-color) srgb r g b/0.24);
}
.button-outlined-body {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.button-filled-body, .button-fab-body {
  background-color: color(from var(--body-color) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
}
.button-filled-body:hover, .button-fab-body:hover {
  background-color: color(from var(--body-color) srgb r g b/0.18);
}
.button-filled-body:active, .button-fab-body:active {
  background-color: color(from var(--body-color) srgb r g b/0.24);
}
.button-outlined-surface-primary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--surface-primary-color) var(--elevation-mix-1), transparent);
}
.button-filled-surface-primary, .button-fab-surface-primary {
  background-color: color(from var(--surface-primary-color) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--surface-primary-color) var(--elevation-mix-2), transparent);
}
.button-filled-surface-primary:hover, .button-fab-surface-primary:hover {
  background-color: color(from var(--surface-primary-color) srgb r g b/0.18);
}
.button-filled-surface-primary:active, .button-fab-surface-primary:active {
  background-color: color(from var(--surface-primary-color) srgb r g b/0.24);
}
.button-outlined-surface-secondary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--surface-secondary-color) var(--elevation-mix-1), transparent);
}
.button-filled-surface-secondary, .button-fab-surface-secondary {
  background-color: color(from var(--surface-secondary-color) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--surface-secondary-color) var(--elevation-mix-2), transparent);
}
.button-filled-surface-secondary:hover, .button-fab-surface-secondary:hover {
  background-color: color(from var(--surface-secondary-color) srgb r g b/0.18);
}
.button-filled-surface-secondary:active, .button-fab-surface-secondary:active {
  background-color: color(from var(--surface-secondary-color) srgb r g b/0.24);
}
.button-outlined-primary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--primary-color) var(--elevation-mix-1), transparent);
}
.button-filled-primary, .button-fab-primary {
  color: var(--base-primary);
  background-color: color(from var(--base-primary) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--primary-color) var(--elevation-mix-2), transparent);
}
.button-filled-primary:hover, .button-fab-primary:hover {
  background-color: color(from var(--base-primary) srgb r g b/0.18);
}
.button-filled-primary:active, .button-fab-primary:active {
  background-color: color(from var(--base-primary) srgb r g b/0.24);
}
.button-outlined-secondary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--secondary-color) var(--elevation-mix-1), transparent);
}
.button-filled-secondary, .button-fab-secondary {
  color: var(--base-secondary);
  background-color: color(from var(--base-secondary) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--secondary-color) var(--elevation-mix-2), transparent);
}
.button-filled-secondary:hover, .button-fab-secondary:hover {
  background-color: color(from var(--base-secondary) srgb r g b/0.18);
}
.button-filled-secondary:active, .button-fab-secondary:active {
  background-color: color(from var(--base-secondary) srgb r g b/0.24);
}
.button-outlined-tertiary {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--tertiary-color) var(--elevation-mix-1), transparent);
}
.button-filled-tertiary, .button-fab-tertiary {
  color: var(--base-tertiary);
  background-color: color(from var(--base-tertiary) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--tertiary-color) var(--elevation-mix-2), transparent);
}
.button-filled-tertiary:hover, .button-fab-tertiary:hover {
  background-color: color(from var(--base-tertiary) srgb r g b/0.18);
}
.button-filled-tertiary:active, .button-fab-tertiary:active {
  background-color: color(from var(--base-tertiary) srgb r g b/0.24);
}
.button-outlined-success {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--success-color) var(--elevation-mix-1), transparent);
}
.button-filled-success, .button-fab-success {
  color: var(--base-success);
  background-color: color(from var(--base-success) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--success-color) var(--elevation-mix-2), transparent);
}
.button-filled-success:hover, .button-fab-success:hover {
  background-color: color(from var(--base-success) srgb r g b/0.18);
}
.button-filled-success:active, .button-fab-success:active {
  background-color: color(from var(--base-success) srgb r g b/0.24);
}
.button-outlined-info {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--info-color) var(--elevation-mix-1), transparent);
}
.button-filled-info, .button-fab-info {
  color: var(--base-info);
  background-color: color(from var(--base-info) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--info-color) var(--elevation-mix-2), transparent);
}
.button-filled-info:hover, .button-fab-info:hover {
  background-color: color(from var(--base-info) srgb r g b/0.18);
}
.button-filled-info:active, .button-fab-info:active {
  background-color: color(from var(--base-info) srgb r g b/0.24);
}
.button-outlined-warning {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--warning-color) var(--elevation-mix-1), transparent);
}
.button-filled-warning, .button-fab-warning {
  color: var(--base-warning);
  background-color: color(from var(--base-warning) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--warning-color) var(--elevation-mix-2), transparent);
}
.button-filled-warning:hover, .button-fab-warning:hover {
  background-color: color(from var(--base-warning) srgb r g b/0.18);
}
.button-filled-warning:active, .button-fab-warning:active {
  background-color: color(from var(--base-warning) srgb r g b/0.24);
}
.button-outlined-danger {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--danger-color) var(--elevation-mix-1), transparent);
}
.button-filled-danger, .button-fab-danger {
  color: var(--base-danger);
  background-color: color(from var(--base-danger) srgb r g b/0.12);
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--danger-color) var(--elevation-mix-2), transparent);
}
.button-filled-danger:hover, .button-fab-danger:hover {
  background-color: color(from var(--base-danger) srgb r g b/0.18);
}
.button-filled-danger:active, .button-fab-danger:active {
  background-color: color(from var(--base-danger) srgb r g b/0.24);
}
.button-group {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.button-group > .button {
  box-shadow: none;
}
.button-group > .button-fab {
  border-radius: var(--border-radius);
}
.button-group > .button-fab + .button-fab {
  margin-inline-start: calc(var(--space-base) * -1.5);
}

.graphic {
  color: color-mix(in srgb, currentColor 80%, transparent);
}

.graphic-svg {
  filter: drop-shadow(0 0 0.25rem color-mix(in srgb, currentColor 25%, transparent));
}

.list-group {
  box-shadow: var(--elevation-size-1) color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
}
.list-group > li {
  border-color: color-mix(in srgb, var(--body-color) 12%, transparent);
}

.header-item {
  transition: box-shadow var(--animation-duration) var(--animation-ease), translate var(--animation-duration) var(--animation-ease);
}
.header-item::before {
  display: none;
}
.header-item:hover:not(:active):not(:disabled):not([aria-disabled=true]) {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  translate: 0 -2px;
}
.layout {
  --_layout-zone-margin: var(--space-2);
}
.layout-header, .layout-navbar, .layout-sidebar, .layout-footer {
  backdrop-filter: var(--neo-blur);
  border: 0.25px solid color-mix(in srgb, currentcolor 8%, transparent);
  border-radius: var(--border-radius);
  box-shadow: var(--elevation-size-3) color-mix(in srgb, var(--body-color) var(--elevation-mix-3), transparent);
  margin: var(--_layout-zone-margin);
}
.layout-navbar {
  inset-block-start: var(--_layout-zone-margin);
}
.layout-sidebar {
  background: color(from var(--body-color) srgb r g b/0.03);
  backdrop-filter: var(--neo-blur) saturate(140%);
}
.drawer {
  background: color(from var(--body-color) srgb r g b/0.03);
  backdrop-filter: var(--neo-blur) saturate(140%);
}

.menu-link {
  transition: box-shadow var(--animation-duration) var(--animation-ease), translate var(--animation-duration) var(--animation-ease);
}
.menu-link::before {
  display: none;
}
.menu-link:hover:not(:active):not(:disabled):not([aria-disabled=true]) {
  box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  translate: 0 -2px;
}
}
@media (min-width: 37.5rem){
  .visible-phone {
    display: none;
  }
  .hidden-phone {
    display: block;
  }
  .order-tablet-first {
    order: -1;
  }
  .order-tablet-0 {
    order: 0;
  }
  .order-tablet-1 {
    order: 1;
  }
  .order-tablet-2 {
    order: 2;
  }
  .order-tablet-3 {
    order: 3;
  }
  .order-tablet-4 {
    order: 4;
  }
  .order-tablet-last {
    order: 5;
  }
  .grid2 {
    grid-template-columns: repeat(2, 1fr);
  }
  .grid-tiles {
    grid-template-columns: repeat(3, 1fr);
  }
  .grid-cards {
    grid-template-columns: repeat(2, 1fr);
  }
  .grid-trios {
    grid-template-columns: repeat(2, 1fr);
  }
  .grid-sidebar {
    grid-template-columns: 1fr 2fr;
  }
  .grid-sidebar-end {
    grid-template-columns: 2fr 1fr;
  }
  .grid-bento {
    grid-template-columns: repeat(4, 1fr);
    grid-auto-flow: dense;
  }
  .grid-bento > * {
    grid-column: span 2;
  }
  .grid-bento > .featured {
    grid-column: span 2;
    grid-row: span 2;
  }
  .grid-bento > .wide {
    grid-column: span 2;
  }
  .grid-bento > .tall {
    grid-column: span 1;
    grid-row: span 2;
  }
  .grid-bento > .small {
    grid-column: span 1;
  }
  .grid-masonry {
    columns: 2;
  }
  .jumbotron {
    padding-block: calc(var(--space-5) * 1.5);
    padding-inline: var(--space-5);
  }
  .timeline-centered {
    padding-inline-start: 0;
  }
  .timeline-centered::before {
    inset-inline-start: 50%;
    transform: translateX(-50%);
  }
  .timeline-centered .timeline-item {
    inline-size: 50%;
    padding-inline-start: var(--space-5);
    padding-inline-end: 0;
  }
  .timeline-centered .timeline-item:nth-child(odd) {
    margin-inline-start: 50%;
  }
  .timeline-centered .timeline-item:nth-child(even) {
    margin-inline-start: 0;
    padding-inline-start: 0;
    padding-inline-end: var(--space-5);
    text-align: end;
  }
  .timeline-centered .timeline-item:nth-child(odd) .timeline-icon {
    inset-inline-start: calc(-0.75rem - var(--space-5));
  }
  .timeline-centered .timeline-item:nth-child(even) .timeline-icon {
    inset-inline-start: auto;
    inset-inline-end: calc(-0.75rem - var(--space-5));
  }
  .footer .footer-body {
    grid-template-columns: 1fr 1fr;
  }
  .footer-collapse .footer-body {
    grid-template-columns: 1fr 1fr;
  }
  .header {
    gap: var(--space-3);
  }
  .header-item {
    flex: none;
    min-width: 5rem;
  }
  .header-item-label {
    display: block;
  }
  .layout-header > [aria-controls=layout-sidebar],
  .layout-header > [aria-controls=navbar-collapse] {
    display: none;
  }
  .layout-main {
    display: flex;
    flex-direction: row;
  }
  .layout-sidebar {
    display: block;
    position: sticky;
    inset-block-start: calc(var(--layout-navbar-height) + var(--_layout-zone-margin));
    z-index: 10;
    height: calc(100dvh - var(--layout-navbar-height) - var(--_layout-zone-margin) * 2);
    flex-shrink: 0;
    width: 4rem;
    overflow: hidden;
    background: transparent;
    transition: width var(--animation-duration) var(--animation-ease);
  }
  /* Kill the base slide animation at tablet+ (needs matching specificity) */
  .layout-sidebar:not([aria-hidden=true]) {
    animation: none;
  }
  .layout-sidebar[aria-hidden=true] {
    width: 0;
    margin: 0;
    border: 0;
    box-shadow: none;
  }
  .layout-sidebar-drawer-header {
    display: none;
  }
  .layout-article {
    flex: 1;
    min-width: 0;
  }
  .layout-footer {
    display: block;
  }
  #goTopButton.show {
    display: block;
    opacity: 1;
  }
  @starting-style {
    #goTopButton.show {
      opacity: 0;
    }
  }
}
@media (min-width: 37.5rem) and (max-width: calc(77.5rem - 0.0625rem)){
  .visible-tablet {
    display: block;
  }
  .hidden-tablet {
    display: none;
  }
  .navbar-collapse {
    position: absolute;
    inset-block-start: 100%;
    inset-block-end: unset;
  }
  .menu-vertical[data-responsive] > li > .menu-link > .menu-text, .menu-vertical[data-responsive] > li > .menu-link > .chevron, .menu-vertical[data-responsive] > .menu-header, .menu-vertical[data-responsive] > li[role=separator] {
    display: none;
  }
  .menu-vertical[data-responsive] > li > .menu-link {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--space-2);
  }
  .menu-vertical[data-responsive] > li > .menu-link > .menu-icon {
    margin: 0;
  }
  .menu-vertical[data-responsive] > li > .menu-link > .menu-abbr {
    display: flex;
  }
  .menu-vertical[data-responsive] .menu-group {
    position: relative;
  }
  .menu-vertical[data-responsive] .menu-group > .menu-collapse {
    display: none;
    grid-template-rows: unset;
    overflow: visible;
    position: absolute;
    inset-inline-start: 100%;
    inset-block-start: 0;
    min-inline-size: 15rem;
    inline-size: max-content;
    background: var(--surface-primary-bg);
    border: 1px solid var(--surface-secondary-bg);
    border-radius: var(--border-radius);
    box-shadow: 0 var(--elevation-size-2) calc(var(--elevation-size-2) * 2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
    z-index: 100;
    transition: none;
    white-space: nowrap;
  }
  .menu-vertical[data-responsive] .menu-group > .menu-collapse > ul {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    max-block-size: 50dvh;
    padding: var(--space-1);
    min-block-size: unset;
  }
  .menu-vertical[data-responsive] .menu-link[aria-expanded=true] + .menu-collapse {
    display: block;
    --_enter-distance: 0.625rem;
    animation: neo-slide-inline-end var(--animation-duration) var(--animation-ease);
  }
  /* Ancestor overflow for flyout escape */
  .layout-sidebar:has(.menu-vertical[data-responsive]):not([aria-hidden=true]),
  .sidebar:has(.menu-vertical[data-responsive]) {
    overflow: visible;
  }
}
@media (min-width: 77.5rem){
  .order-laptop-first {
    order: -1;
  }
  .order-laptop-0 {
    order: 0;
  }
  .order-laptop-1 {
    order: 1;
  }
  .order-laptop-2 {
    order: 2;
  }
  .order-laptop-3 {
    order: 3;
  }
  .order-laptop-4 {
    order: 4;
  }
  .order-laptop-last {
    order: 5;
  }
  .grid-tiles {
    grid-template-columns: repeat(4, 1fr);
  }
  .grid-cards {
    grid-template-columns: repeat(3, 1fr);
  }
  .grid-trios {
    grid-template-columns: repeat(3, 1fr);
  }
  .grid-sidebar {
    grid-template-columns: 1fr 3fr;
  }
  .grid-sidebar-end {
    grid-template-columns: 3fr 1fr;
  }
  .grid-masonry {
    columns: 3;
  }
  .footer .footer-body {
    grid-template-columns: 2fr 1fr 1fr;
  }
  .footer.footer-featured-layout .footer-body {
    grid-template-columns: 2fr 1fr 1fr 1fr;
  }
  .footer-collapse .footer-body {
    grid-template-columns: 2fr 1fr 1fr;
  }
  .layout-sidebar {
    width: 16rem;
  }
  .sidebar {
    padding: var(--space-2);
    white-space: nowrap;
    overflow-x: hidden;
  }
}
@media (min-width: 77.5rem) and (max-width: calc(90rem - 0.0625rem)){
  .visible-laptop {
    display: block;
  }
  .hidden-laptop {
    display: none;
  }
}
@media (min-width: 90rem){
  .order-desktop-first {
    order: -1;
  }
  .order-desktop-0 {
    order: 0;
  }
  .order-desktop-1 {
    order: 1;
  }
  .order-desktop-2 {
    order: 2;
  }
  .order-desktop-3 {
    order: 3;
  }
  .order-desktop-4 {
    order: 4;
  }
  .order-desktop-last {
    order: 5;
  }
  .grid-tiles {
    grid-template-columns: repeat(6, 1fr);
  }
  .grid-cards {
    grid-template-columns: repeat(4, 1fr);
  }
  .grid-sidebar {
    grid-template-columns: 1fr 4fr;
  }
  .grid-sidebar-end {
    grid-template-columns: 4fr 1fr;
  }
  .grid-masonry {
    columns: 4;
  }
}
@media (min-width: 90rem) and (max-width: calc(120rem - 0.0625rem)){
  .visible-desktop {
    display: block;
  }
  .hidden-desktop {
    display: none;
  }
}
@media (min-width: 120rem){
  .order-wall-first {
    order: -1;
  }
  .order-wall-0 {
    order: 0;
  }
  .order-wall-1 {
    order: 1;
  }
  .order-wall-2 {
    order: 2;
  }
  .order-wall-3 {
    order: 3;
  }
  .order-wall-4 {
    order: 4;
  }
  .order-wall-last {
    order: 5;
  }
  .grid-tiles {
    grid-template-columns: repeat(8, 1fr);
  }
}
@media (min-width: 120rem) and (max-width: calc(160rem - 0.0625rem)){
  .visible-wall {
    display: block;
  }
  .hidden-wall {
    display: none;
  }
}
@media (min-width: 160rem){
  .visible-ultra {
    display: block;
  }
  .hidden-ultra {
    display: none;
  }
  .order-ultra-first {
    order: -1;
  }
  .order-ultra-0 {
    order: 0;
  }
  .order-ultra-1 {
    order: 1;
  }
  .order-ultra-2 {
    order: 2;
  }
  .order-ultra-3 {
    order: 3;
  }
  .order-ultra-4 {
    order: 4;
  }
  .order-ultra-last {
    order: 5;
  }
  .grid-tiles {
    grid-template-columns: repeat(10, 1fr);
  }
}
@media (max-width: calc(77.5rem - 0.0625rem)){
  [aria-controls=navbar-collapse] {
    margin-inline-start: auto;
    display: flex;
  }
  /* nav menu + actions hidden by default, animated open */
  .navbar-collapse {
    flex: none;
    flex-direction: column-reverse;
    align-items: stretch;
    position: fixed;
    inset-inline: 0;
    z-index: 300;
    background: var(--surface-primary-bg);
    border: 1px solid var(--surface-secondary-bg);
    border-radius: var(--border-radius);
    padding: var(--space-4);
    gap: var(--space-3);
    max-block-size: calc(100dvh - var(--layout-navbar-height));
    overflow-y: auto;
    display: none;
  }
  /* open state */
  .navbar-collapse:not([aria-hidden=true]) {
    display: flex;
    --_enter-distance: 0.625rem;
    animation: neo-slide-down var(--animation-duration) var(--animation-ease);
  }
  [data-surface=material] .navbar-collapse {
    border: 0;
    box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  }
  /* ── Surface: Neo ─────────────────────────────────────────────── */
  [data-surface=neo] .navbar-collapse {
    border: 0;
    background: color(from var(--body-color) srgb r g b/0.03);
    backdrop-filter: var(--neo-blur) saturate(140%);
    box-shadow: var(--elevation-size-2) color-mix(in srgb, var(--body-color) var(--elevation-mix-2), transparent);
  }
  .menu-horizontal[data-responsive] {
    flex-direction: column;
    align-items: stretch;
  }
  .menu-horizontal[data-responsive] > .menu-item {
    display: block;
  }
  .menu-horizontal[data-responsive] > .menu-item > .menu-link {
    inline-size: 100%;
  }
  .menu-horizontal[data-responsive] .menu-group > .menu-collapse {
    position: static;
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows var(--animation-duration) var(--animation-ease);
    min-inline-size: unset;
    inline-size: auto;
    white-space: normal;
    background: none;
    border: none;
    border-radius: 0;
    box-shadow: none;
    z-index: auto;
  }
  .menu-horizontal[data-responsive] .menu-group > .menu-collapse > * {
    overflow: hidden;
    min-block-size: 0;
  }
  .menu-horizontal[data-responsive] .menu-group > .menu-collapse > ul {
    display: block;
    max-block-size: unset;
    flex-wrap: nowrap;
    padding-inline-start: var(--space-3);
    padding-block: 0;
  }
  .menu-horizontal[data-responsive] .menu-link[aria-expanded=true] + .menu-collapse {
    grid-template-rows: 1fr;
  }
  .menu-horizontal[data-responsive] .menu-collapse .menu-group > .menu-collapse {
    inset-inline-start: unset;
    inset-block-start: unset;
  }
}
@media (max-width: calc(37.5rem - 0.0625rem)){
  html::-webkit-scrollbar {
    width: 0;
    height: 0;
    display: none;
  }
  html {
    scrollbar-width: none;
    overflow-y: scroll;
  }
  .expander-toggle {
    display: block;
    border: none;
    background: none;
    font: inherit;
    color: inherit;
    padding: 0;
    cursor: pointer;
  }
  .expander-content {
    position: absolute;
    inset-inline: 0;
    z-index: 100;
    background-color: var(--body-bg);
    display: none;
  }
  .expander-toggle[aria-expanded=true] + .expander-content {
    display: block;
    padding: var(--space-2);
    --_enter-distance: 0.625rem;
    animation: neo-slide-down var(--animation-duration) var(--animation-ease);
  }
  .table-responsive,
  .table-responsive tbody,
  .table-responsive th,
  .table-responsive td,
  .table-responsive tr {
    display: block;
  }
  .table-responsive thead {
    position: absolute;
    inline-size: 1px;
    block-size: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
  }
  .table-responsive td {
    display: flex;
    justify-content: space-between;
    padding-inline: var(--space-3);
  }
  .table-responsive td::before {
    content: attr(data-label);
    font-weight: 700;
    padding-inline-end: var(--space-3);
  }
  .table-responsive td:first-child {
    font-weight: 700;
  }
  .table-responsive td:last-child {
    border-block-end: var(--border-width) solid var(--body-color);
    margin-block-end: var(--space-3);
  }
  .header {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    padding: 0;
  }
  .header a,
  .header button {
    flex: 0 0 calc(var(--space-base) * 8);
    width: calc(var(--space-base) * 8);
    height: calc(var(--space-base) * 8);
  }
  .layout-navbar {
    display: contents;
  }
  .layout-header {
    order: 5;
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    position: sticky;
    inset-block-end: 0;
    z-index: 250;
    border-block-end: 0;
    border-block-start: var(--border-width) solid color-mix(in srgb, currentcolor 12%, transparent);
  }
  .layout-main {
    order: 3;
    min-height: 100dvh;
  }
  .layout-footer {
    order: 6;
  }
  .layout-brand h3 {
    display: none;
  }
  [data-surface=material] .layout-header {
    border-block-end: 0;
    box-shadow: 0 -0.125rem 0.25rem color-mix(in srgb, var(--body-color) var(--elevation-mix-1), transparent);
  }
  [data-surface=neo] .layout-header {
    margin: 0;
    border-radius: 0;
  }
  .navbar {
    display: contents;
  }
  .navbar > *:not(.navbar-collapse) {
    display: none;
  }
  .navbar-collapse {
    inset-block-start: unset;
    inset-block-end: var(--layout-header-height);
  }
  .navbar-collapse:not([aria-hidden=true]) {
    --_enter-distance: 0.625rem;
    animation: neo-slide-up var(--animation-duration) var(--animation-ease);
  }
  .curtain {
    flex-direction: column;
    block-size: auto;
  }
  .curtain-panel {
    flex-basis: auto;
    padding: var(--space-4);
    block-size: 100dvh;
  }
  .curtain-panel:hover {
    flex-basis: auto;
  }
  .drawer-right,
  .drawer-left {
    width: 100%;
  }
  .menu-dropdown-wrapper[data-responsive] > .menu-link[aria-expanded=true] + .menu-dropdown {
    position: fixed;
    inset-inline: 0;
    inset-block-end: 0;
    inset-block-start: auto;
    min-inline-size: unset;
    inline-size: 100%;
    max-block-size: 75dvh;
    white-space: normal;
    z-index: 450;
    border-radius: var(--border-radius) var(--border-radius) 0 0;
    overflow-y: auto;
    flex-wrap: nowrap;
  }
  .parallax {
    align-items: end;
  }
}
@media (prefers-reduced-motion: reduce){
  :root {
    --animation-duration: 0ms;
  }
  * {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}
@media print{
  .print-hidden {
    display: none;
  }
  .print-only {
    display: block;
  }
  .card,
  .tile {
    box-shadow: none;
    border: none;
  }
  nav,
  .sidebar,
  .navbar,
  .footer,
  .drawer,
  .backdrop {
    display: none;
  }
  body {
    padding: 0;
    margin: 0;
  }
}
