/* main.scss
   VOR Core (base + utilities + components)
*/
/* palette.scss - Full Spectrum Master Map */
/* main.scss
   VOR Core (base + utilities + components)
*/
/* variables.scss */
/* --------------------------------------------
   Helpers
-------------------------------------------- */
/* --------------------------------------------
   Breakpoints
-------------------------------------------- */
/* --------------------------------------------
   Spacing
-------------------------------------------- */
/* --------------------------------------------
   Elevation
-------------------------------------------- */
/* --------------------------------------------
   Radius
-------------------------------------------- */
/* --------------------------------------------
   Typography
-------------------------------------------- */
/* --------------------------------------------
   Theme tokens
-------------------------------------------- */
:root {
  /* Brand */
  --primary: #2dd4bf;
  --primary-light: #ccfbf1;
  --primary-dark: #042f2e;
  --accent: #f97316;
  /* RGB channels for focus rings etc */
  --primary-rgb: 45 212 191;
  /* Status */
  --success: #16a34a;
  --info: #0d6efd;
  --warning: #eab308;
  --danger: #dc2626;
  /* Surfaces */
  --bg-app: #fbfcfd;
  --bg-surface: #f8f9fa;
  --bg-card: #ffffff;
  --border-color: #e9ecef;
  /* Text */
  --text-main: #212529;
  --text-muted: #495057;
  --text-light: #adb5bd;
  --text-inverse: #ffffff;
  --table-header-bg: var(--bg-surface);
  --table-striped-bg: #fbfcfd;
  --table-hover-bg: rgba(var(--primary-rgb), 0.06);
}

[data-theme=dark] {
  --primary: #2dd4bf;
  --primary-light: #115e59;
  --primary-rgb: 45 212 191;
  --bg-app: #212529;
  --bg-surface: #212529;
  --bg-card: #343a40;
  --border-color: #495057;
  --text-main: #f8f9fa;
  --text-muted: #ced4da;
  --text-light: #6c757d;
  --table-header-bg: var(--bg-surface);
  --table-striped-bg: rgba(255,255,255,0.03);
  --table-hover-bg: rgba(var(--primary-rgb), 0.10);
}

/* --------------------------------------------
   SASS aliases to CSS vars
-------------------------------------------- */
/* --------------------------------------------
   Z-index
-------------------------------------------- */
/* --------------------------------------------
   Grid & layout maps
-------------------------------------------- */
/* --------------------------------------------
   Components baseline tokens
-------------------------------------------- */
/* sizing maps */
/* motion */
/* focus ring */
/* sidebar */
/* --------------------------------------------
   Base reset
-------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-family: "Roboto", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  -moz-tab-size: 4;
  -o-tab-size: 4;
     tab-size: 4;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-size: 1rem;
  font-weight: 400;
  color: var(--text-main);
  background-color: var(--bg-app);
  transition: background-color 250ms cubic-bezier(0.4, 0, 0.2, 1), color 250ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* Media defaults */
img, svg, video, canvas {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Links */
a {
  color: inherit;
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

/* Accessible focus (default; components can override) */
:focus-visible {
  outline: none;
}

/* --------------------------------------------
   Token helpers
-------------------------------------------- */
.bg-app {
  background-color: var(--bg-app) !important;
}

.bg-surface {
  background-color: var(--bg-surface) !important;
}

.bg-card {
  background-color: var(--bg-card) !important;
}

.text-main {
  color: var(--text-main) !important;
}

.text-muted {
  color: var(--text-muted) !important;
}

.text-light {
  color: var(--text-light) !important;
}

.text-inverse {
  color: var(--text-inverse) !important;
}

/* --------------------------------------------
   Containers / Grid (gutter via CSS vars)
-------------------------------------------- */
:root {
  --gutter-x: 1rem;
  --gutter-y: 0;
}

.container,
.container-fluid {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 576px) {
  .container {
    max-width: 540px;
  }
}
@media (min-width: 768px) {
  .container {
    max-width: 720px;
  }
}
@media (min-width: 992px) {
  .container {
    max-width: 960px;
  }
}
@media (min-width: 1200px) {
  .container {
    max-width: 1140px;
  }
}
@media (min-width: 1400px) {
  .container {
    max-width: 1320px;
  }
}
.row {
  display: flex;
  flex-wrap: wrap;
  /* row controls gutters */
  --gutter-x: 1rem;
  --gutter-y: 0;
  margin-top: calc(var(--gutter-y) * -1);
  margin-right: calc(var(--gutter-x) / -2);
  margin-left: calc(var(--gutter-x) / -2);
}
.row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--gutter-x) / 2);
  padding-left: calc(var(--gutter-x) / 2);
  margin-top: var(--gutter-y);
}

.row-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

/* gutter utilities */
.g-0 {
  --gutter-x: 0;
  --gutter-y: 0;
}

.gx-0 {
  --gutter-x: 0;
}

.gy-0 {
  --gutter-y: 0;
}

/* IMPORTANT: no @extend across media queries */
@media (min-width: 0) {
  .col-1 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 8.3333333333%;
  }
  .col-2 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-3 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 25%;
  }
  .col-4 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .col-5 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 41.6666666667%;
  }
  .col-6 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 50%;
  }
  .col-7 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 58.3333333333%;
  }
  .col-8 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 66.6666666667%;
  }
  .col-9 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 75%;
  }
  .col-10 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 83.3333333333%;
  }
  .col-11 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 91.6666666667%;
  }
  .col-12 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 100%;
  }
  .col {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 1 0 0%;
  }
  .col-auto {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: auto;
  }
}
@media (min-width: 576px) {
  .col-sm-1 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 8.3333333333%;
  }
  .col-sm-2 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-sm-3 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 25%;
  }
  .col-sm-4 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .col-sm-5 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 41.6666666667%;
  }
  .col-sm-6 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 50%;
  }
  .col-sm-7 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 58.3333333333%;
  }
  .col-sm-8 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 66.6666666667%;
  }
  .col-sm-9 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 75%;
  }
  .col-sm-10 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 83.3333333333%;
  }
  .col-sm-11 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 91.6666666667%;
  }
  .col-sm-12 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 100%;
  }
  .col-sm {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 1 0 0%;
  }
  .col-sm-auto {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: auto;
  }
}
@media (min-width: 768px) {
  .col-md-1 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 8.3333333333%;
  }
  .col-md-2 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-md-3 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 25%;
  }
  .col-md-4 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .col-md-5 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 41.6666666667%;
  }
  .col-md-6 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 50%;
  }
  .col-md-7 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 58.3333333333%;
  }
  .col-md-8 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 66.6666666667%;
  }
  .col-md-9 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 75%;
  }
  .col-md-10 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 83.3333333333%;
  }
  .col-md-11 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 91.6666666667%;
  }
  .col-md-12 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 100%;
  }
  .col-md {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 1 0 0%;
  }
  .col-md-auto {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: auto;
  }
}
@media (min-width: 992px) {
  .col-lg-1 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 8.3333333333%;
  }
  .col-lg-2 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-lg-3 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 25%;
  }
  .col-lg-4 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .col-lg-5 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 41.6666666667%;
  }
  .col-lg-6 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 50%;
  }
  .col-lg-7 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 58.3333333333%;
  }
  .col-lg-8 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 66.6666666667%;
  }
  .col-lg-9 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 75%;
  }
  .col-lg-10 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 83.3333333333%;
  }
  .col-lg-11 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 91.6666666667%;
  }
  .col-lg-12 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 100%;
  }
  .col-lg {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 1 0 0%;
  }
  .col-lg-auto {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: auto;
  }
}
@media (min-width: 1200px) {
  .col-xl-1 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 8.3333333333%;
  }
  .col-xl-2 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-xl-3 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 25%;
  }
  .col-xl-4 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .col-xl-5 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 41.6666666667%;
  }
  .col-xl-6 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 50%;
  }
  .col-xl-7 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 58.3333333333%;
  }
  .col-xl-8 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 66.6666666667%;
  }
  .col-xl-9 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 75%;
  }
  .col-xl-10 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 83.3333333333%;
  }
  .col-xl-11 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 91.6666666667%;
  }
  .col-xl-12 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 100%;
  }
  .col-xl {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 1 0 0%;
  }
  .col-xl-auto {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: auto;
  }
}
@media (min-width: 1400px) {
  .col-xxl-1 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 8.3333333333%;
  }
  .col-xxl-2 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 16.6666666667%;
  }
  .col-xxl-3 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 25%;
  }
  .col-xxl-4 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 33.3333333333%;
  }
  .col-xxl-5 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 41.6666666667%;
  }
  .col-xxl-6 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 50%;
  }
  .col-xxl-7 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 58.3333333333%;
  }
  .col-xxl-8 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 66.6666666667%;
  }
  .col-xxl-9 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 75%;
  }
  .col-xxl-10 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 83.3333333333%;
  }
  .col-xxl-11 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 91.6666666667%;
  }
  .col-xxl-12 {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: 100%;
  }
  .col-xxl {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 1 0 0%;
  }
  .col-xxl-auto {
    width: 100%;
    padding-right: calc(var(--gutter-x) / 2);
    padding-left: calc(var(--gutter-x) / 2);
    flex: 0 0 auto;
    width: auto;
  }
}
/* --------------------------------------------
   Display / Flex utilities
-------------------------------------------- */
@media (min-width: 0) {
  .d-none {
    display: none !important;
  }
  .d-block {
    display: block !important;
  }
  .d-inline {
    display: inline !important;
  }
  .d-inline-block {
    display: inline-block !important;
  }
  .d-flex {
    display: flex !important;
  }
  .d-inline-flex {
    display: inline-flex !important;
  }
  .d-grid {
    display: grid !important;
  }
  .justify-start {
    justify-content: flex-start !important;
  }
  .justify-end {
    justify-content: flex-end !important;
  }
  .justify-center {
    justify-content: center !important;
  }
  .justify-between {
    justify-content: space-between !important;
  }
  .justify-around {
    justify-content: space-around !important;
  }
  .justify-evenly {
    justify-content: space-evenly !important;
  }
  .align-start {
    align-items: flex-start !important;
  }
  .align-end {
    align-items: flex-end !important;
  }
  .align-center {
    align-items: center !important;
  }
  .align-baseline {
    align-items: baseline !important;
  }
  .align-stretch {
    align-items: stretch !important;
  }
  .flex-row {
    flex-direction: row !important;
  }
  .flex-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-column {
    flex-direction: column !important;
  }
  .flex-column-reverse {
    flex-direction: column-reverse !important;
  }
}
@media (min-width: 576px) {
  .d-sm-none {
    display: none !important;
  }
  .d-sm-block {
    display: block !important;
  }
  .d-sm-inline {
    display: inline !important;
  }
  .d-sm-inline-block {
    display: inline-block !important;
  }
  .d-sm-flex {
    display: flex !important;
  }
  .d-sm-inline-flex {
    display: inline-flex !important;
  }
  .d-sm-grid {
    display: grid !important;
  }
  .justify-sm-start {
    justify-content: flex-start !important;
  }
  .justify-sm-end {
    justify-content: flex-end !important;
  }
  .justify-sm-center {
    justify-content: center !important;
  }
  .justify-sm-between {
    justify-content: space-between !important;
  }
  .justify-sm-around {
    justify-content: space-around !important;
  }
  .justify-sm-evenly {
    justify-content: space-evenly !important;
  }
  .align-sm-start {
    align-items: flex-start !important;
  }
  .align-sm-end {
    align-items: flex-end !important;
  }
  .align-sm-center {
    align-items: center !important;
  }
  .align-sm-baseline {
    align-items: baseline !important;
  }
  .align-sm-stretch {
    align-items: stretch !important;
  }
  .flex-sm-row {
    flex-direction: row !important;
  }
  .flex-sm-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-sm-column {
    flex-direction: column !important;
  }
  .flex-sm-column-reverse {
    flex-direction: column-reverse !important;
  }
}
@media (min-width: 768px) {
  .d-md-none {
    display: none !important;
  }
  .d-md-block {
    display: block !important;
  }
  .d-md-inline {
    display: inline !important;
  }
  .d-md-inline-block {
    display: inline-block !important;
  }
  .d-md-flex {
    display: flex !important;
  }
  .d-md-inline-flex {
    display: inline-flex !important;
  }
  .d-md-grid {
    display: grid !important;
  }
  .justify-md-start {
    justify-content: flex-start !important;
  }
  .justify-md-end {
    justify-content: flex-end !important;
  }
  .justify-md-center {
    justify-content: center !important;
  }
  .justify-md-between {
    justify-content: space-between !important;
  }
  .justify-md-around {
    justify-content: space-around !important;
  }
  .justify-md-evenly {
    justify-content: space-evenly !important;
  }
  .align-md-start {
    align-items: flex-start !important;
  }
  .align-md-end {
    align-items: flex-end !important;
  }
  .align-md-center {
    align-items: center !important;
  }
  .align-md-baseline {
    align-items: baseline !important;
  }
  .align-md-stretch {
    align-items: stretch !important;
  }
  .flex-md-row {
    flex-direction: row !important;
  }
  .flex-md-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-md-column {
    flex-direction: column !important;
  }
  .flex-md-column-reverse {
    flex-direction: column-reverse !important;
  }
}
@media (min-width: 992px) {
  .d-lg-none {
    display: none !important;
  }
  .d-lg-block {
    display: block !important;
  }
  .d-lg-inline {
    display: inline !important;
  }
  .d-lg-inline-block {
    display: inline-block !important;
  }
  .d-lg-flex {
    display: flex !important;
  }
  .d-lg-inline-flex {
    display: inline-flex !important;
  }
  .d-lg-grid {
    display: grid !important;
  }
  .justify-lg-start {
    justify-content: flex-start !important;
  }
  .justify-lg-end {
    justify-content: flex-end !important;
  }
  .justify-lg-center {
    justify-content: center !important;
  }
  .justify-lg-between {
    justify-content: space-between !important;
  }
  .justify-lg-around {
    justify-content: space-around !important;
  }
  .justify-lg-evenly {
    justify-content: space-evenly !important;
  }
  .align-lg-start {
    align-items: flex-start !important;
  }
  .align-lg-end {
    align-items: flex-end !important;
  }
  .align-lg-center {
    align-items: center !important;
  }
  .align-lg-baseline {
    align-items: baseline !important;
  }
  .align-lg-stretch {
    align-items: stretch !important;
  }
  .flex-lg-row {
    flex-direction: row !important;
  }
  .flex-lg-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-lg-column {
    flex-direction: column !important;
  }
  .flex-lg-column-reverse {
    flex-direction: column-reverse !important;
  }
}
@media (min-width: 1200px) {
  .d-xl-none {
    display: none !important;
  }
  .d-xl-block {
    display: block !important;
  }
  .d-xl-inline {
    display: inline !important;
  }
  .d-xl-inline-block {
    display: inline-block !important;
  }
  .d-xl-flex {
    display: flex !important;
  }
  .d-xl-inline-flex {
    display: inline-flex !important;
  }
  .d-xl-grid {
    display: grid !important;
  }
  .justify-xl-start {
    justify-content: flex-start !important;
  }
  .justify-xl-end {
    justify-content: flex-end !important;
  }
  .justify-xl-center {
    justify-content: center !important;
  }
  .justify-xl-between {
    justify-content: space-between !important;
  }
  .justify-xl-around {
    justify-content: space-around !important;
  }
  .justify-xl-evenly {
    justify-content: space-evenly !important;
  }
  .align-xl-start {
    align-items: flex-start !important;
  }
  .align-xl-end {
    align-items: flex-end !important;
  }
  .align-xl-center {
    align-items: center !important;
  }
  .align-xl-baseline {
    align-items: baseline !important;
  }
  .align-xl-stretch {
    align-items: stretch !important;
  }
  .flex-xl-row {
    flex-direction: row !important;
  }
  .flex-xl-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-xl-column {
    flex-direction: column !important;
  }
  .flex-xl-column-reverse {
    flex-direction: column-reverse !important;
  }
}
@media (min-width: 1400px) {
  .d-xxl-none {
    display: none !important;
  }
  .d-xxl-block {
    display: block !important;
  }
  .d-xxl-inline {
    display: inline !important;
  }
  .d-xxl-inline-block {
    display: inline-block !important;
  }
  .d-xxl-flex {
    display: flex !important;
  }
  .d-xxl-inline-flex {
    display: inline-flex !important;
  }
  .d-xxl-grid {
    display: grid !important;
  }
  .justify-xxl-start {
    justify-content: flex-start !important;
  }
  .justify-xxl-end {
    justify-content: flex-end !important;
  }
  .justify-xxl-center {
    justify-content: center !important;
  }
  .justify-xxl-between {
    justify-content: space-between !important;
  }
  .justify-xxl-around {
    justify-content: space-around !important;
  }
  .justify-xxl-evenly {
    justify-content: space-evenly !important;
  }
  .align-xxl-start {
    align-items: flex-start !important;
  }
  .align-xxl-end {
    align-items: flex-end !important;
  }
  .align-xxl-center {
    align-items: center !important;
  }
  .align-xxl-baseline {
    align-items: baseline !important;
  }
  .align-xxl-stretch {
    align-items: stretch !important;
  }
  .flex-xxl-row {
    flex-direction: row !important;
  }
  .flex-xxl-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-xxl-column {
    flex-direction: column !important;
  }
  .flex-xxl-column-reverse {
    flex-direction: column-reverse !important;
  }
}
/* Convenience */
.flex-column {
  flex-direction: column !important;
}

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

.min-w-0 {
  min-width: 0 !important;
}

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

.h-100 {
  height: 100% !important;
}

/* --------------------------------------------
   Spacing utilities (generator)
-------------------------------------------- */
@media (min-width: 0) {
  .mt-0 {
    margin-top: 0 !important;
  }
  .mt-1 {
    margin-top: 0.25rem !important;
  }
  .mt-2 {
    margin-top: 0.5rem !important;
  }
  .mt-3 {
    margin-top: 1rem !important;
  }
  .mt-4 {
    margin-top: 1.5rem !important;
  }
  .mt-5 {
    margin-top: 2rem !important;
  }
  .mt-6 {
    margin-top: 3rem !important;
  }
  .mt-7 {
    margin-top: 4rem !important;
  }
  .mb-0 {
    margin-bottom: 0 !important;
  }
  .mb-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-3 {
    margin-bottom: 1rem !important;
  }
  .mb-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-5 {
    margin-bottom: 2rem !important;
  }
  .mb-6 {
    margin-bottom: 3rem !important;
  }
  .mb-7 {
    margin-bottom: 4rem !important;
  }
  .ms-0 {
    margin-start: 0 !important;
  }
  .ms-1 {
    margin-start: 0.25rem !important;
  }
  .ms-2 {
    margin-start: 0.5rem !important;
  }
  .ms-3 {
    margin-start: 1rem !important;
  }
  .ms-4 {
    margin-start: 1.5rem !important;
  }
  .ms-5 {
    margin-start: 2rem !important;
  }
  .ms-6 {
    margin-start: 3rem !important;
  }
  .ms-7 {
    margin-start: 4rem !important;
  }
  .me-0 {
    margin-end: 0 !important;
  }
  .me-1 {
    margin-end: 0.25rem !important;
  }
  .me-2 {
    margin-end: 0.5rem !important;
  }
  .me-3 {
    margin-end: 1rem !important;
  }
  .me-4 {
    margin-end: 1.5rem !important;
  }
  .me-5 {
    margin-end: 2rem !important;
  }
  .me-6 {
    margin-end: 3rem !important;
  }
  .me-7 {
    margin-end: 4rem !important;
  }
  .mx-0 {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .mx-1 {
    margin-left: 0.25rem !important;
    margin-right: 0.25rem !important;
  }
  .mx-2 {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .mx-3 {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .mx-4 {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .mx-5 {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .mx-6 {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .mx-7 {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .my-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-5 {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .my-6 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-7 {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .ma-0 {
    margin: 0 !important;
  }
  .ma-1 {
    margin: 0.25rem !important;
  }
  .ma-2 {
    margin: 0.5rem !important;
  }
  .ma-3 {
    margin: 1rem !important;
  }
  .ma-4 {
    margin: 1.5rem !important;
  }
  .ma-5 {
    margin: 2rem !important;
  }
  .ma-6 {
    margin: 3rem !important;
  }
  .ma-7 {
    margin: 4rem !important;
  }
  .pt-0 {
    padding-top: 0 !important;
  }
  .pt-1 {
    padding-top: 0.25rem !important;
  }
  .pt-2 {
    padding-top: 0.5rem !important;
  }
  .pt-3 {
    padding-top: 1rem !important;
  }
  .pt-4 {
    padding-top: 1.5rem !important;
  }
  .pt-5 {
    padding-top: 2rem !important;
  }
  .pt-6 {
    padding-top: 3rem !important;
  }
  .pt-7 {
    padding-top: 4rem !important;
  }
  .pb-0 {
    padding-bottom: 0 !important;
  }
  .pb-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-3 {
    padding-bottom: 1rem !important;
  }
  .pb-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-5 {
    padding-bottom: 2rem !important;
  }
  .pb-6 {
    padding-bottom: 3rem !important;
  }
  .pb-7 {
    padding-bottom: 4rem !important;
  }
  .ps-0 {
    padding-start: 0 !important;
  }
  .ps-1 {
    padding-start: 0.25rem !important;
  }
  .ps-2 {
    padding-start: 0.5rem !important;
  }
  .ps-3 {
    padding-start: 1rem !important;
  }
  .ps-4 {
    padding-start: 1.5rem !important;
  }
  .ps-5 {
    padding-start: 2rem !important;
  }
  .ps-6 {
    padding-start: 3rem !important;
  }
  .ps-7 {
    padding-start: 4rem !important;
  }
  .pe-0 {
    padding-end: 0 !important;
  }
  .pe-1 {
    padding-end: 0.25rem !important;
  }
  .pe-2 {
    padding-end: 0.5rem !important;
  }
  .pe-3 {
    padding-end: 1rem !important;
  }
  .pe-4 {
    padding-end: 1.5rem !important;
  }
  .pe-5 {
    padding-end: 2rem !important;
  }
  .pe-6 {
    padding-end: 3rem !important;
  }
  .pe-7 {
    padding-end: 4rem !important;
  }
  .px-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .px-1 {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
  }
  .px-2 {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .px-3 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .px-4 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .px-5 {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .px-6 {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .px-7 {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .py-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-5 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .py-6 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .py-7 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .pa-0 {
    padding: 0 !important;
  }
  .pa-1 {
    padding: 0.25rem !important;
  }
  .pa-2 {
    padding: 0.5rem !important;
  }
  .pa-3 {
    padding: 1rem !important;
  }
  .pa-4 {
    padding: 1.5rem !important;
  }
  .pa-5 {
    padding: 2rem !important;
  }
  .pa-6 {
    padding: 3rem !important;
  }
  .pa-7 {
    padding: 4rem !important;
  }
}
@media (min-width: 576px) {
  .mt-sm-0 {
    margin-top: 0 !important;
  }
  .mt-sm-1 {
    margin-top: 0.25rem !important;
  }
  .mt-sm-2 {
    margin-top: 0.5rem !important;
  }
  .mt-sm-3 {
    margin-top: 1rem !important;
  }
  .mt-sm-4 {
    margin-top: 1.5rem !important;
  }
  .mt-sm-5 {
    margin-top: 2rem !important;
  }
  .mt-sm-6 {
    margin-top: 3rem !important;
  }
  .mt-sm-7 {
    margin-top: 4rem !important;
  }
  .mb-sm-0 {
    margin-bottom: 0 !important;
  }
  .mb-sm-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-sm-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-sm-3 {
    margin-bottom: 1rem !important;
  }
  .mb-sm-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-sm-5 {
    margin-bottom: 2rem !important;
  }
  .mb-sm-6 {
    margin-bottom: 3rem !important;
  }
  .mb-sm-7 {
    margin-bottom: 4rem !important;
  }
  .ms-sm-0 {
    margin-start: 0 !important;
  }
  .ms-sm-1 {
    margin-start: 0.25rem !important;
  }
  .ms-sm-2 {
    margin-start: 0.5rem !important;
  }
  .ms-sm-3 {
    margin-start: 1rem !important;
  }
  .ms-sm-4 {
    margin-start: 1.5rem !important;
  }
  .ms-sm-5 {
    margin-start: 2rem !important;
  }
  .ms-sm-6 {
    margin-start: 3rem !important;
  }
  .ms-sm-7 {
    margin-start: 4rem !important;
  }
  .me-sm-0 {
    margin-end: 0 !important;
  }
  .me-sm-1 {
    margin-end: 0.25rem !important;
  }
  .me-sm-2 {
    margin-end: 0.5rem !important;
  }
  .me-sm-3 {
    margin-end: 1rem !important;
  }
  .me-sm-4 {
    margin-end: 1.5rem !important;
  }
  .me-sm-5 {
    margin-end: 2rem !important;
  }
  .me-sm-6 {
    margin-end: 3rem !important;
  }
  .me-sm-7 {
    margin-end: 4rem !important;
  }
  .mx-sm-0 {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .mx-sm-1 {
    margin-left: 0.25rem !important;
    margin-right: 0.25rem !important;
  }
  .mx-sm-2 {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .mx-sm-3 {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .mx-sm-4 {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .mx-sm-5 {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .mx-sm-6 {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .mx-sm-7 {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .my-sm-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-sm-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-sm-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-sm-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-sm-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-sm-5 {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .my-sm-6 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-sm-7 {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .ma-sm-0 {
    margin: 0 !important;
  }
  .ma-sm-1 {
    margin: 0.25rem !important;
  }
  .ma-sm-2 {
    margin: 0.5rem !important;
  }
  .ma-sm-3 {
    margin: 1rem !important;
  }
  .ma-sm-4 {
    margin: 1.5rem !important;
  }
  .ma-sm-5 {
    margin: 2rem !important;
  }
  .ma-sm-6 {
    margin: 3rem !important;
  }
  .ma-sm-7 {
    margin: 4rem !important;
  }
  .pt-sm-0 {
    padding-top: 0 !important;
  }
  .pt-sm-1 {
    padding-top: 0.25rem !important;
  }
  .pt-sm-2 {
    padding-top: 0.5rem !important;
  }
  .pt-sm-3 {
    padding-top: 1rem !important;
  }
  .pt-sm-4 {
    padding-top: 1.5rem !important;
  }
  .pt-sm-5 {
    padding-top: 2rem !important;
  }
  .pt-sm-6 {
    padding-top: 3rem !important;
  }
  .pt-sm-7 {
    padding-top: 4rem !important;
  }
  .pb-sm-0 {
    padding-bottom: 0 !important;
  }
  .pb-sm-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-sm-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-sm-3 {
    padding-bottom: 1rem !important;
  }
  .pb-sm-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-sm-5 {
    padding-bottom: 2rem !important;
  }
  .pb-sm-6 {
    padding-bottom: 3rem !important;
  }
  .pb-sm-7 {
    padding-bottom: 4rem !important;
  }
  .ps-sm-0 {
    padding-start: 0 !important;
  }
  .ps-sm-1 {
    padding-start: 0.25rem !important;
  }
  .ps-sm-2 {
    padding-start: 0.5rem !important;
  }
  .ps-sm-3 {
    padding-start: 1rem !important;
  }
  .ps-sm-4 {
    padding-start: 1.5rem !important;
  }
  .ps-sm-5 {
    padding-start: 2rem !important;
  }
  .ps-sm-6 {
    padding-start: 3rem !important;
  }
  .ps-sm-7 {
    padding-start: 4rem !important;
  }
  .pe-sm-0 {
    padding-end: 0 !important;
  }
  .pe-sm-1 {
    padding-end: 0.25rem !important;
  }
  .pe-sm-2 {
    padding-end: 0.5rem !important;
  }
  .pe-sm-3 {
    padding-end: 1rem !important;
  }
  .pe-sm-4 {
    padding-end: 1.5rem !important;
  }
  .pe-sm-5 {
    padding-end: 2rem !important;
  }
  .pe-sm-6 {
    padding-end: 3rem !important;
  }
  .pe-sm-7 {
    padding-end: 4rem !important;
  }
  .px-sm-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .px-sm-1 {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
  }
  .px-sm-2 {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .px-sm-3 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .px-sm-4 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .px-sm-5 {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .px-sm-6 {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .px-sm-7 {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .py-sm-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-sm-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-sm-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-sm-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-sm-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-sm-5 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .py-sm-6 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .py-sm-7 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .pa-sm-0 {
    padding: 0 !important;
  }
  .pa-sm-1 {
    padding: 0.25rem !important;
  }
  .pa-sm-2 {
    padding: 0.5rem !important;
  }
  .pa-sm-3 {
    padding: 1rem !important;
  }
  .pa-sm-4 {
    padding: 1.5rem !important;
  }
  .pa-sm-5 {
    padding: 2rem !important;
  }
  .pa-sm-6 {
    padding: 3rem !important;
  }
  .pa-sm-7 {
    padding: 4rem !important;
  }
}
@media (min-width: 768px) {
  .mt-md-0 {
    margin-top: 0 !important;
  }
  .mt-md-1 {
    margin-top: 0.25rem !important;
  }
  .mt-md-2 {
    margin-top: 0.5rem !important;
  }
  .mt-md-3 {
    margin-top: 1rem !important;
  }
  .mt-md-4 {
    margin-top: 1.5rem !important;
  }
  .mt-md-5 {
    margin-top: 2rem !important;
  }
  .mt-md-6 {
    margin-top: 3rem !important;
  }
  .mt-md-7 {
    margin-top: 4rem !important;
  }
  .mb-md-0 {
    margin-bottom: 0 !important;
  }
  .mb-md-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-md-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-md-3 {
    margin-bottom: 1rem !important;
  }
  .mb-md-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-md-5 {
    margin-bottom: 2rem !important;
  }
  .mb-md-6 {
    margin-bottom: 3rem !important;
  }
  .mb-md-7 {
    margin-bottom: 4rem !important;
  }
  .ms-md-0 {
    margin-start: 0 !important;
  }
  .ms-md-1 {
    margin-start: 0.25rem !important;
  }
  .ms-md-2 {
    margin-start: 0.5rem !important;
  }
  .ms-md-3 {
    margin-start: 1rem !important;
  }
  .ms-md-4 {
    margin-start: 1.5rem !important;
  }
  .ms-md-5 {
    margin-start: 2rem !important;
  }
  .ms-md-6 {
    margin-start: 3rem !important;
  }
  .ms-md-7 {
    margin-start: 4rem !important;
  }
  .me-md-0 {
    margin-end: 0 !important;
  }
  .me-md-1 {
    margin-end: 0.25rem !important;
  }
  .me-md-2 {
    margin-end: 0.5rem !important;
  }
  .me-md-3 {
    margin-end: 1rem !important;
  }
  .me-md-4 {
    margin-end: 1.5rem !important;
  }
  .me-md-5 {
    margin-end: 2rem !important;
  }
  .me-md-6 {
    margin-end: 3rem !important;
  }
  .me-md-7 {
    margin-end: 4rem !important;
  }
  .mx-md-0 {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .mx-md-1 {
    margin-left: 0.25rem !important;
    margin-right: 0.25rem !important;
  }
  .mx-md-2 {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .mx-md-3 {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .mx-md-4 {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .mx-md-5 {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .mx-md-6 {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .mx-md-7 {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .my-md-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-md-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-md-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-md-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-md-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-md-5 {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .my-md-6 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-md-7 {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .ma-md-0 {
    margin: 0 !important;
  }
  .ma-md-1 {
    margin: 0.25rem !important;
  }
  .ma-md-2 {
    margin: 0.5rem !important;
  }
  .ma-md-3 {
    margin: 1rem !important;
  }
  .ma-md-4 {
    margin: 1.5rem !important;
  }
  .ma-md-5 {
    margin: 2rem !important;
  }
  .ma-md-6 {
    margin: 3rem !important;
  }
  .ma-md-7 {
    margin: 4rem !important;
  }
  .pt-md-0 {
    padding-top: 0 !important;
  }
  .pt-md-1 {
    padding-top: 0.25rem !important;
  }
  .pt-md-2 {
    padding-top: 0.5rem !important;
  }
  .pt-md-3 {
    padding-top: 1rem !important;
  }
  .pt-md-4 {
    padding-top: 1.5rem !important;
  }
  .pt-md-5 {
    padding-top: 2rem !important;
  }
  .pt-md-6 {
    padding-top: 3rem !important;
  }
  .pt-md-7 {
    padding-top: 4rem !important;
  }
  .pb-md-0 {
    padding-bottom: 0 !important;
  }
  .pb-md-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-md-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-md-3 {
    padding-bottom: 1rem !important;
  }
  .pb-md-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-md-5 {
    padding-bottom: 2rem !important;
  }
  .pb-md-6 {
    padding-bottom: 3rem !important;
  }
  .pb-md-7 {
    padding-bottom: 4rem !important;
  }
  .ps-md-0 {
    padding-start: 0 !important;
  }
  .ps-md-1 {
    padding-start: 0.25rem !important;
  }
  .ps-md-2 {
    padding-start: 0.5rem !important;
  }
  .ps-md-3 {
    padding-start: 1rem !important;
  }
  .ps-md-4 {
    padding-start: 1.5rem !important;
  }
  .ps-md-5 {
    padding-start: 2rem !important;
  }
  .ps-md-6 {
    padding-start: 3rem !important;
  }
  .ps-md-7 {
    padding-start: 4rem !important;
  }
  .pe-md-0 {
    padding-end: 0 !important;
  }
  .pe-md-1 {
    padding-end: 0.25rem !important;
  }
  .pe-md-2 {
    padding-end: 0.5rem !important;
  }
  .pe-md-3 {
    padding-end: 1rem !important;
  }
  .pe-md-4 {
    padding-end: 1.5rem !important;
  }
  .pe-md-5 {
    padding-end: 2rem !important;
  }
  .pe-md-6 {
    padding-end: 3rem !important;
  }
  .pe-md-7 {
    padding-end: 4rem !important;
  }
  .px-md-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .px-md-1 {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
  }
  .px-md-2 {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .px-md-3 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .px-md-4 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .px-md-5 {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .px-md-6 {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .px-md-7 {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .py-md-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-md-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-md-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-md-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-md-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-md-5 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .py-md-6 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .py-md-7 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .pa-md-0 {
    padding: 0 !important;
  }
  .pa-md-1 {
    padding: 0.25rem !important;
  }
  .pa-md-2 {
    padding: 0.5rem !important;
  }
  .pa-md-3 {
    padding: 1rem !important;
  }
  .pa-md-4 {
    padding: 1.5rem !important;
  }
  .pa-md-5 {
    padding: 2rem !important;
  }
  .pa-md-6 {
    padding: 3rem !important;
  }
  .pa-md-7 {
    padding: 4rem !important;
  }
}
@media (min-width: 992px) {
  .mt-lg-0 {
    margin-top: 0 !important;
  }
  .mt-lg-1 {
    margin-top: 0.25rem !important;
  }
  .mt-lg-2 {
    margin-top: 0.5rem !important;
  }
  .mt-lg-3 {
    margin-top: 1rem !important;
  }
  .mt-lg-4 {
    margin-top: 1.5rem !important;
  }
  .mt-lg-5 {
    margin-top: 2rem !important;
  }
  .mt-lg-6 {
    margin-top: 3rem !important;
  }
  .mt-lg-7 {
    margin-top: 4rem !important;
  }
  .mb-lg-0 {
    margin-bottom: 0 !important;
  }
  .mb-lg-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-lg-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-lg-3 {
    margin-bottom: 1rem !important;
  }
  .mb-lg-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-lg-5 {
    margin-bottom: 2rem !important;
  }
  .mb-lg-6 {
    margin-bottom: 3rem !important;
  }
  .mb-lg-7 {
    margin-bottom: 4rem !important;
  }
  .ms-lg-0 {
    margin-start: 0 !important;
  }
  .ms-lg-1 {
    margin-start: 0.25rem !important;
  }
  .ms-lg-2 {
    margin-start: 0.5rem !important;
  }
  .ms-lg-3 {
    margin-start: 1rem !important;
  }
  .ms-lg-4 {
    margin-start: 1.5rem !important;
  }
  .ms-lg-5 {
    margin-start: 2rem !important;
  }
  .ms-lg-6 {
    margin-start: 3rem !important;
  }
  .ms-lg-7 {
    margin-start: 4rem !important;
  }
  .me-lg-0 {
    margin-end: 0 !important;
  }
  .me-lg-1 {
    margin-end: 0.25rem !important;
  }
  .me-lg-2 {
    margin-end: 0.5rem !important;
  }
  .me-lg-3 {
    margin-end: 1rem !important;
  }
  .me-lg-4 {
    margin-end: 1.5rem !important;
  }
  .me-lg-5 {
    margin-end: 2rem !important;
  }
  .me-lg-6 {
    margin-end: 3rem !important;
  }
  .me-lg-7 {
    margin-end: 4rem !important;
  }
  .mx-lg-0 {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .mx-lg-1 {
    margin-left: 0.25rem !important;
    margin-right: 0.25rem !important;
  }
  .mx-lg-2 {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .mx-lg-3 {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .mx-lg-4 {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .mx-lg-5 {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .mx-lg-6 {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .mx-lg-7 {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .my-lg-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-lg-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-lg-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-lg-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-lg-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-lg-5 {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .my-lg-6 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-lg-7 {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .ma-lg-0 {
    margin: 0 !important;
  }
  .ma-lg-1 {
    margin: 0.25rem !important;
  }
  .ma-lg-2 {
    margin: 0.5rem !important;
  }
  .ma-lg-3 {
    margin: 1rem !important;
  }
  .ma-lg-4 {
    margin: 1.5rem !important;
  }
  .ma-lg-5 {
    margin: 2rem !important;
  }
  .ma-lg-6 {
    margin: 3rem !important;
  }
  .ma-lg-7 {
    margin: 4rem !important;
  }
  .pt-lg-0 {
    padding-top: 0 !important;
  }
  .pt-lg-1 {
    padding-top: 0.25rem !important;
  }
  .pt-lg-2 {
    padding-top: 0.5rem !important;
  }
  .pt-lg-3 {
    padding-top: 1rem !important;
  }
  .pt-lg-4 {
    padding-top: 1.5rem !important;
  }
  .pt-lg-5 {
    padding-top: 2rem !important;
  }
  .pt-lg-6 {
    padding-top: 3rem !important;
  }
  .pt-lg-7 {
    padding-top: 4rem !important;
  }
  .pb-lg-0 {
    padding-bottom: 0 !important;
  }
  .pb-lg-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-lg-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-lg-3 {
    padding-bottom: 1rem !important;
  }
  .pb-lg-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-lg-5 {
    padding-bottom: 2rem !important;
  }
  .pb-lg-6 {
    padding-bottom: 3rem !important;
  }
  .pb-lg-7 {
    padding-bottom: 4rem !important;
  }
  .ps-lg-0 {
    padding-start: 0 !important;
  }
  .ps-lg-1 {
    padding-start: 0.25rem !important;
  }
  .ps-lg-2 {
    padding-start: 0.5rem !important;
  }
  .ps-lg-3 {
    padding-start: 1rem !important;
  }
  .ps-lg-4 {
    padding-start: 1.5rem !important;
  }
  .ps-lg-5 {
    padding-start: 2rem !important;
  }
  .ps-lg-6 {
    padding-start: 3rem !important;
  }
  .ps-lg-7 {
    padding-start: 4rem !important;
  }
  .pe-lg-0 {
    padding-end: 0 !important;
  }
  .pe-lg-1 {
    padding-end: 0.25rem !important;
  }
  .pe-lg-2 {
    padding-end: 0.5rem !important;
  }
  .pe-lg-3 {
    padding-end: 1rem !important;
  }
  .pe-lg-4 {
    padding-end: 1.5rem !important;
  }
  .pe-lg-5 {
    padding-end: 2rem !important;
  }
  .pe-lg-6 {
    padding-end: 3rem !important;
  }
  .pe-lg-7 {
    padding-end: 4rem !important;
  }
  .px-lg-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .px-lg-1 {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
  }
  .px-lg-2 {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .px-lg-3 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .px-lg-4 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .px-lg-5 {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .px-lg-6 {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .px-lg-7 {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .py-lg-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-lg-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-lg-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-lg-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-lg-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-lg-5 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .py-lg-6 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .py-lg-7 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .pa-lg-0 {
    padding: 0 !important;
  }
  .pa-lg-1 {
    padding: 0.25rem !important;
  }
  .pa-lg-2 {
    padding: 0.5rem !important;
  }
  .pa-lg-3 {
    padding: 1rem !important;
  }
  .pa-lg-4 {
    padding: 1.5rem !important;
  }
  .pa-lg-5 {
    padding: 2rem !important;
  }
  .pa-lg-6 {
    padding: 3rem !important;
  }
  .pa-lg-7 {
    padding: 4rem !important;
  }
}
@media (min-width: 1200px) {
  .mt-xl-0 {
    margin-top: 0 !important;
  }
  .mt-xl-1 {
    margin-top: 0.25rem !important;
  }
  .mt-xl-2 {
    margin-top: 0.5rem !important;
  }
  .mt-xl-3 {
    margin-top: 1rem !important;
  }
  .mt-xl-4 {
    margin-top: 1.5rem !important;
  }
  .mt-xl-5 {
    margin-top: 2rem !important;
  }
  .mt-xl-6 {
    margin-top: 3rem !important;
  }
  .mt-xl-7 {
    margin-top: 4rem !important;
  }
  .mb-xl-0 {
    margin-bottom: 0 !important;
  }
  .mb-xl-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-xl-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-xl-3 {
    margin-bottom: 1rem !important;
  }
  .mb-xl-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-xl-5 {
    margin-bottom: 2rem !important;
  }
  .mb-xl-6 {
    margin-bottom: 3rem !important;
  }
  .mb-xl-7 {
    margin-bottom: 4rem !important;
  }
  .ms-xl-0 {
    margin-start: 0 !important;
  }
  .ms-xl-1 {
    margin-start: 0.25rem !important;
  }
  .ms-xl-2 {
    margin-start: 0.5rem !important;
  }
  .ms-xl-3 {
    margin-start: 1rem !important;
  }
  .ms-xl-4 {
    margin-start: 1.5rem !important;
  }
  .ms-xl-5 {
    margin-start: 2rem !important;
  }
  .ms-xl-6 {
    margin-start: 3rem !important;
  }
  .ms-xl-7 {
    margin-start: 4rem !important;
  }
  .me-xl-0 {
    margin-end: 0 !important;
  }
  .me-xl-1 {
    margin-end: 0.25rem !important;
  }
  .me-xl-2 {
    margin-end: 0.5rem !important;
  }
  .me-xl-3 {
    margin-end: 1rem !important;
  }
  .me-xl-4 {
    margin-end: 1.5rem !important;
  }
  .me-xl-5 {
    margin-end: 2rem !important;
  }
  .me-xl-6 {
    margin-end: 3rem !important;
  }
  .me-xl-7 {
    margin-end: 4rem !important;
  }
  .mx-xl-0 {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .mx-xl-1 {
    margin-left: 0.25rem !important;
    margin-right: 0.25rem !important;
  }
  .mx-xl-2 {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .mx-xl-3 {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .mx-xl-4 {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .mx-xl-5 {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .mx-xl-6 {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .mx-xl-7 {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .my-xl-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-xl-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-xl-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-xl-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-xl-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-xl-5 {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .my-xl-6 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-xl-7 {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .ma-xl-0 {
    margin: 0 !important;
  }
  .ma-xl-1 {
    margin: 0.25rem !important;
  }
  .ma-xl-2 {
    margin: 0.5rem !important;
  }
  .ma-xl-3 {
    margin: 1rem !important;
  }
  .ma-xl-4 {
    margin: 1.5rem !important;
  }
  .ma-xl-5 {
    margin: 2rem !important;
  }
  .ma-xl-6 {
    margin: 3rem !important;
  }
  .ma-xl-7 {
    margin: 4rem !important;
  }
  .pt-xl-0 {
    padding-top: 0 !important;
  }
  .pt-xl-1 {
    padding-top: 0.25rem !important;
  }
  .pt-xl-2 {
    padding-top: 0.5rem !important;
  }
  .pt-xl-3 {
    padding-top: 1rem !important;
  }
  .pt-xl-4 {
    padding-top: 1.5rem !important;
  }
  .pt-xl-5 {
    padding-top: 2rem !important;
  }
  .pt-xl-6 {
    padding-top: 3rem !important;
  }
  .pt-xl-7 {
    padding-top: 4rem !important;
  }
  .pb-xl-0 {
    padding-bottom: 0 !important;
  }
  .pb-xl-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-xl-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-xl-3 {
    padding-bottom: 1rem !important;
  }
  .pb-xl-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-xl-5 {
    padding-bottom: 2rem !important;
  }
  .pb-xl-6 {
    padding-bottom: 3rem !important;
  }
  .pb-xl-7 {
    padding-bottom: 4rem !important;
  }
  .ps-xl-0 {
    padding-start: 0 !important;
  }
  .ps-xl-1 {
    padding-start: 0.25rem !important;
  }
  .ps-xl-2 {
    padding-start: 0.5rem !important;
  }
  .ps-xl-3 {
    padding-start: 1rem !important;
  }
  .ps-xl-4 {
    padding-start: 1.5rem !important;
  }
  .ps-xl-5 {
    padding-start: 2rem !important;
  }
  .ps-xl-6 {
    padding-start: 3rem !important;
  }
  .ps-xl-7 {
    padding-start: 4rem !important;
  }
  .pe-xl-0 {
    padding-end: 0 !important;
  }
  .pe-xl-1 {
    padding-end: 0.25rem !important;
  }
  .pe-xl-2 {
    padding-end: 0.5rem !important;
  }
  .pe-xl-3 {
    padding-end: 1rem !important;
  }
  .pe-xl-4 {
    padding-end: 1.5rem !important;
  }
  .pe-xl-5 {
    padding-end: 2rem !important;
  }
  .pe-xl-6 {
    padding-end: 3rem !important;
  }
  .pe-xl-7 {
    padding-end: 4rem !important;
  }
  .px-xl-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .px-xl-1 {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
  }
  .px-xl-2 {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .px-xl-3 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .px-xl-4 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .px-xl-5 {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .px-xl-6 {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .px-xl-7 {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .py-xl-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-xl-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-xl-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-xl-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-xl-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-xl-5 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .py-xl-6 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .py-xl-7 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .pa-xl-0 {
    padding: 0 !important;
  }
  .pa-xl-1 {
    padding: 0.25rem !important;
  }
  .pa-xl-2 {
    padding: 0.5rem !important;
  }
  .pa-xl-3 {
    padding: 1rem !important;
  }
  .pa-xl-4 {
    padding: 1.5rem !important;
  }
  .pa-xl-5 {
    padding: 2rem !important;
  }
  .pa-xl-6 {
    padding: 3rem !important;
  }
  .pa-xl-7 {
    padding: 4rem !important;
  }
}
@media (min-width: 1400px) {
  .mt-xxl-0 {
    margin-top: 0 !important;
  }
  .mt-xxl-1 {
    margin-top: 0.25rem !important;
  }
  .mt-xxl-2 {
    margin-top: 0.5rem !important;
  }
  .mt-xxl-3 {
    margin-top: 1rem !important;
  }
  .mt-xxl-4 {
    margin-top: 1.5rem !important;
  }
  .mt-xxl-5 {
    margin-top: 2rem !important;
  }
  .mt-xxl-6 {
    margin-top: 3rem !important;
  }
  .mt-xxl-7 {
    margin-top: 4rem !important;
  }
  .mb-xxl-0 {
    margin-bottom: 0 !important;
  }
  .mb-xxl-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-xxl-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-xxl-3 {
    margin-bottom: 1rem !important;
  }
  .mb-xxl-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-xxl-5 {
    margin-bottom: 2rem !important;
  }
  .mb-xxl-6 {
    margin-bottom: 3rem !important;
  }
  .mb-xxl-7 {
    margin-bottom: 4rem !important;
  }
  .ms-xxl-0 {
    margin-start: 0 !important;
  }
  .ms-xxl-1 {
    margin-start: 0.25rem !important;
  }
  .ms-xxl-2 {
    margin-start: 0.5rem !important;
  }
  .ms-xxl-3 {
    margin-start: 1rem !important;
  }
  .ms-xxl-4 {
    margin-start: 1.5rem !important;
  }
  .ms-xxl-5 {
    margin-start: 2rem !important;
  }
  .ms-xxl-6 {
    margin-start: 3rem !important;
  }
  .ms-xxl-7 {
    margin-start: 4rem !important;
  }
  .me-xxl-0 {
    margin-end: 0 !important;
  }
  .me-xxl-1 {
    margin-end: 0.25rem !important;
  }
  .me-xxl-2 {
    margin-end: 0.5rem !important;
  }
  .me-xxl-3 {
    margin-end: 1rem !important;
  }
  .me-xxl-4 {
    margin-end: 1.5rem !important;
  }
  .me-xxl-5 {
    margin-end: 2rem !important;
  }
  .me-xxl-6 {
    margin-end: 3rem !important;
  }
  .me-xxl-7 {
    margin-end: 4rem !important;
  }
  .mx-xxl-0 {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .mx-xxl-1 {
    margin-left: 0.25rem !important;
    margin-right: 0.25rem !important;
  }
  .mx-xxl-2 {
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
  .mx-xxl-3 {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .mx-xxl-4 {
    margin-left: 1.5rem !important;
    margin-right: 1.5rem !important;
  }
  .mx-xxl-5 {
    margin-left: 2rem !important;
    margin-right: 2rem !important;
  }
  .mx-xxl-6 {
    margin-left: 3rem !important;
    margin-right: 3rem !important;
  }
  .mx-xxl-7 {
    margin-left: 4rem !important;
    margin-right: 4rem !important;
  }
  .my-xxl-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-xxl-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-xxl-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-xxl-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-xxl-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-xxl-5 {
    margin-top: 2rem !important;
    margin-bottom: 2rem !important;
  }
  .my-xxl-6 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-xxl-7 {
    margin-top: 4rem !important;
    margin-bottom: 4rem !important;
  }
  .ma-xxl-0 {
    margin: 0 !important;
  }
  .ma-xxl-1 {
    margin: 0.25rem !important;
  }
  .ma-xxl-2 {
    margin: 0.5rem !important;
  }
  .ma-xxl-3 {
    margin: 1rem !important;
  }
  .ma-xxl-4 {
    margin: 1.5rem !important;
  }
  .ma-xxl-5 {
    margin: 2rem !important;
  }
  .ma-xxl-6 {
    margin: 3rem !important;
  }
  .ma-xxl-7 {
    margin: 4rem !important;
  }
  .pt-xxl-0 {
    padding-top: 0 !important;
  }
  .pt-xxl-1 {
    padding-top: 0.25rem !important;
  }
  .pt-xxl-2 {
    padding-top: 0.5rem !important;
  }
  .pt-xxl-3 {
    padding-top: 1rem !important;
  }
  .pt-xxl-4 {
    padding-top: 1.5rem !important;
  }
  .pt-xxl-5 {
    padding-top: 2rem !important;
  }
  .pt-xxl-6 {
    padding-top: 3rem !important;
  }
  .pt-xxl-7 {
    padding-top: 4rem !important;
  }
  .pb-xxl-0 {
    padding-bottom: 0 !important;
  }
  .pb-xxl-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-xxl-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-xxl-3 {
    padding-bottom: 1rem !important;
  }
  .pb-xxl-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-xxl-5 {
    padding-bottom: 2rem !important;
  }
  .pb-xxl-6 {
    padding-bottom: 3rem !important;
  }
  .pb-xxl-7 {
    padding-bottom: 4rem !important;
  }
  .ps-xxl-0 {
    padding-start: 0 !important;
  }
  .ps-xxl-1 {
    padding-start: 0.25rem !important;
  }
  .ps-xxl-2 {
    padding-start: 0.5rem !important;
  }
  .ps-xxl-3 {
    padding-start: 1rem !important;
  }
  .ps-xxl-4 {
    padding-start: 1.5rem !important;
  }
  .ps-xxl-5 {
    padding-start: 2rem !important;
  }
  .ps-xxl-6 {
    padding-start: 3rem !important;
  }
  .ps-xxl-7 {
    padding-start: 4rem !important;
  }
  .pe-xxl-0 {
    padding-end: 0 !important;
  }
  .pe-xxl-1 {
    padding-end: 0.25rem !important;
  }
  .pe-xxl-2 {
    padding-end: 0.5rem !important;
  }
  .pe-xxl-3 {
    padding-end: 1rem !important;
  }
  .pe-xxl-4 {
    padding-end: 1.5rem !important;
  }
  .pe-xxl-5 {
    padding-end: 2rem !important;
  }
  .pe-xxl-6 {
    padding-end: 3rem !important;
  }
  .pe-xxl-7 {
    padding-end: 4rem !important;
  }
  .px-xxl-0 {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .px-xxl-1 {
    padding-left: 0.25rem !important;
    padding-right: 0.25rem !important;
  }
  .px-xxl-2 {
    padding-left: 0.5rem !important;
    padding-right: 0.5rem !important;
  }
  .px-xxl-3 {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .px-xxl-4 {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .px-xxl-5 {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
  .px-xxl-6 {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
  .px-xxl-7 {
    padding-left: 4rem !important;
    padding-right: 4rem !important;
  }
  .py-xxl-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-xxl-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-xxl-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-xxl-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-xxl-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-xxl-5 {
    padding-top: 2rem !important;
    padding-bottom: 2rem !important;
  }
  .py-xxl-6 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .py-xxl-7 {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
  }
  .pa-xxl-0 {
    padding: 0 !important;
  }
  .pa-xxl-1 {
    padding: 0.25rem !important;
  }
  .pa-xxl-2 {
    padding: 0.5rem !important;
  }
  .pa-xxl-3 {
    padding: 1rem !important;
  }
  .pa-xxl-4 {
    padding: 1.5rem !important;
  }
  .pa-xxl-5 {
    padding: 2rem !important;
  }
  .pa-xxl-6 {
    padding: 3rem !important;
  }
  .pa-xxl-7 {
    padding: 4rem !important;
  }
}
/* Classic alias set (p-0 / px-4 / etc) + gap */
.m-0 {
  margin: 0 !important;
}

.mx-0 {
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.my-0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.mt-0 {
  margin-top: 0 !important;
}

.mb-0 {
  margin-bottom: 0 !important;
}

.ml-0 {
  margin-left: 0 !important;
}

.mr-0 {
  margin-right: 0 !important;
}

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

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

.py-0 {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.pt-0 {
  padding-top: 0 !important;
}

.pb-0 {
  padding-bottom: 0 !important;
}

.pl-0 {
  padding-left: 0 !important;
}

.pr-0 {
  padding-right: 0 !important;
}

.gap-0 {
  gap: 0 !important;
}

.m-1 {
  margin: 0.25rem !important;
}

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

.my-1 {
  margin-top: 0.25rem !important;
  margin-bottom: 0.25rem !important;
}

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

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

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

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

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

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

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

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

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

.pl-1 {
  padding-left: 0.25rem !important;
}

.pr-1 {
  padding-right: 0.25rem !important;
}

.gap-1 {
  gap: 0.25rem !important;
}

.m-2 {
  margin: 0.5rem !important;
}

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

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

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

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

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

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

.p-2 {
  padding: 0.5rem !important;
}

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

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

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

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

.pl-2 {
  padding-left: 0.5rem !important;
}

.pr-2 {
  padding-right: 0.5rem !important;
}

.gap-2 {
  gap: 0.5rem !important;
}

.m-3 {
  margin: 1rem !important;
}

.mx-3 {
  margin-left: 1rem !important;
  margin-right: 1rem !important;
}

.my-3 {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}

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

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

.ml-3 {
  margin-left: 1rem !important;
}

.mr-3 {
  margin-right: 1rem !important;
}

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

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

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

.pt-3 {
  padding-top: 1rem !important;
}

.pb-3 {
  padding-bottom: 1rem !important;
}

.pl-3 {
  padding-left: 1rem !important;
}

.pr-3 {
  padding-right: 1rem !important;
}

.gap-3 {
  gap: 1rem !important;
}

.m-4 {
  margin: 1.5rem !important;
}

.mx-4 {
  margin-left: 1.5rem !important;
  margin-right: 1.5rem !important;
}

.my-4 {
  margin-top: 1.5rem !important;
  margin-bottom: 1.5rem !important;
}

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

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

.ml-4 {
  margin-left: 1.5rem !important;
}

.mr-4 {
  margin-right: 1.5rem !important;
}

.p-4 {
  padding: 1.5rem !important;
}

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

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

.pt-4 {
  padding-top: 1.5rem !important;
}

.pb-4 {
  padding-bottom: 1.5rem !important;
}

.pl-4 {
  padding-left: 1.5rem !important;
}

.pr-4 {
  padding-right: 1.5rem !important;
}

.gap-4 {
  gap: 1.5rem !important;
}

.m-5 {
  margin: 2rem !important;
}

.mx-5 {
  margin-left: 2rem !important;
  margin-right: 2rem !important;
}

.my-5 {
  margin-top: 2rem !important;
  margin-bottom: 2rem !important;
}

.mt-5 {
  margin-top: 2rem !important;
}

.mb-5 {
  margin-bottom: 2rem !important;
}

.ml-5 {
  margin-left: 2rem !important;
}

.mr-5 {
  margin-right: 2rem !important;
}

.p-5 {
  padding: 2rem !important;
}

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

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

.pt-5 {
  padding-top: 2rem !important;
}

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

.pl-5 {
  padding-left: 2rem !important;
}

.pr-5 {
  padding-right: 2rem !important;
}

.gap-5 {
  gap: 2rem !important;
}

.m-6 {
  margin: 3rem !important;
}

.mx-6 {
  margin-left: 3rem !important;
  margin-right: 3rem !important;
}

.my-6 {
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
}

.mt-6 {
  margin-top: 3rem !important;
}

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

.ml-6 {
  margin-left: 3rem !important;
}

.mr-6 {
  margin-right: 3rem !important;
}

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

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

.py-6 {
  padding-top: 3rem !important;
  padding-bottom: 3rem !important;
}

.pt-6 {
  padding-top: 3rem !important;
}

.pb-6 {
  padding-bottom: 3rem !important;
}

.pl-6 {
  padding-left: 3rem !important;
}

.pr-6 {
  padding-right: 3rem !important;
}

.gap-6 {
  gap: 3rem !important;
}

.m-7 {
  margin: 4rem !important;
}

.mx-7 {
  margin-left: 4rem !important;
  margin-right: 4rem !important;
}

.my-7 {
  margin-top: 4rem !important;
  margin-bottom: 4rem !important;
}

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

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

.ml-7 {
  margin-left: 4rem !important;
}

.mr-7 {
  margin-right: 4rem !important;
}

.p-7 {
  padding: 4rem !important;
}

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

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

.pt-7 {
  padding-top: 4rem !important;
}

.pb-7 {
  padding-bottom: 4rem !important;
}

.pl-7 {
  padding-left: 4rem !important;
}

.pr-7 {
  padding-right: 4rem !important;
}

.gap-7 {
  gap: 4rem !important;
}

/* --------------------------------------------
   Sizing utilities + responsive widths/heights
-------------------------------------------- */
.w-25 {
  width: 25% !important;
}

.h-25 {
  height: 25% !important;
}

.w-33 {
  width: 33.33% !important;
}

.h-33 {
  height: 33.33% !important;
}

.w-50 {
  width: 50% !important;
}

.h-50 {
  height: 50% !important;
}

.w-66 {
  width: 66.66% !important;
}

.h-66 {
  height: 66.66% !important;
}

.w-75 {
  width: 75% !important;
}

.h-75 {
  height: 75% !important;
}

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

.h-100 {
  height: 100% !important;
}

.w-auto {
  width: auto !important;
}

.h-auto {
  height: auto !important;
}

.w-screen-v {
  width: 100vh !important;
}

.h-screen-v {
  height: 100vh !important;
}

.w-screen-h {
  width: 100vw !important;
}

.h-screen-h {
  height: 100vw !important;
}

@media (min-width: 0) {
  .w-25 {
    width: 25% !important;
  }
  .h-25 {
    height: 25% !important;
  }
  .w-33 {
    width: 33.33% !important;
  }
  .h-33 {
    height: 33.33% !important;
  }
  .w-50 {
    width: 50% !important;
  }
  .h-50 {
    height: 50% !important;
  }
  .w-66 {
    width: 66.66% !important;
  }
  .h-66 {
    height: 66.66% !important;
  }
  .w-75 {
    width: 75% !important;
  }
  .h-75 {
    height: 75% !important;
  }
  .w-100 {
    width: 100% !important;
  }
  .h-100 {
    height: 100% !important;
  }
  .w-auto {
    width: auto !important;
  }
  .h-auto {
    height: auto !important;
  }
  .w-screen-v {
    width: 100vh !important;
  }
  .h-screen-v {
    height: 100vh !important;
  }
  .w-screen-h {
    width: 100vw !important;
  }
  .h-screen-h {
    height: 100vw !important;
  }
}
@media (min-width: 576px) {
  .w-sm-25 {
    width: 25% !important;
  }
  .h-sm-25 {
    height: 25% !important;
  }
  .w-sm-33 {
    width: 33.33% !important;
  }
  .h-sm-33 {
    height: 33.33% !important;
  }
  .w-sm-50 {
    width: 50% !important;
  }
  .h-sm-50 {
    height: 50% !important;
  }
  .w-sm-66 {
    width: 66.66% !important;
  }
  .h-sm-66 {
    height: 66.66% !important;
  }
  .w-sm-75 {
    width: 75% !important;
  }
  .h-sm-75 {
    height: 75% !important;
  }
  .w-sm-100 {
    width: 100% !important;
  }
  .h-sm-100 {
    height: 100% !important;
  }
  .w-sm-auto {
    width: auto !important;
  }
  .h-sm-auto {
    height: auto !important;
  }
  .w-sm-screen-v {
    width: 100vh !important;
  }
  .h-sm-screen-v {
    height: 100vh !important;
  }
  .w-sm-screen-h {
    width: 100vw !important;
  }
  .h-sm-screen-h {
    height: 100vw !important;
  }
}
@media (min-width: 768px) {
  .w-md-25 {
    width: 25% !important;
  }
  .h-md-25 {
    height: 25% !important;
  }
  .w-md-33 {
    width: 33.33% !important;
  }
  .h-md-33 {
    height: 33.33% !important;
  }
  .w-md-50 {
    width: 50% !important;
  }
  .h-md-50 {
    height: 50% !important;
  }
  .w-md-66 {
    width: 66.66% !important;
  }
  .h-md-66 {
    height: 66.66% !important;
  }
  .w-md-75 {
    width: 75% !important;
  }
  .h-md-75 {
    height: 75% !important;
  }
  .w-md-100 {
    width: 100% !important;
  }
  .h-md-100 {
    height: 100% !important;
  }
  .w-md-auto {
    width: auto !important;
  }
  .h-md-auto {
    height: auto !important;
  }
  .w-md-screen-v {
    width: 100vh !important;
  }
  .h-md-screen-v {
    height: 100vh !important;
  }
  .w-md-screen-h {
    width: 100vw !important;
  }
  .h-md-screen-h {
    height: 100vw !important;
  }
}
@media (min-width: 992px) {
  .w-lg-25 {
    width: 25% !important;
  }
  .h-lg-25 {
    height: 25% !important;
  }
  .w-lg-33 {
    width: 33.33% !important;
  }
  .h-lg-33 {
    height: 33.33% !important;
  }
  .w-lg-50 {
    width: 50% !important;
  }
  .h-lg-50 {
    height: 50% !important;
  }
  .w-lg-66 {
    width: 66.66% !important;
  }
  .h-lg-66 {
    height: 66.66% !important;
  }
  .w-lg-75 {
    width: 75% !important;
  }
  .h-lg-75 {
    height: 75% !important;
  }
  .w-lg-100 {
    width: 100% !important;
  }
  .h-lg-100 {
    height: 100% !important;
  }
  .w-lg-auto {
    width: auto !important;
  }
  .h-lg-auto {
    height: auto !important;
  }
  .w-lg-screen-v {
    width: 100vh !important;
  }
  .h-lg-screen-v {
    height: 100vh !important;
  }
  .w-lg-screen-h {
    width: 100vw !important;
  }
  .h-lg-screen-h {
    height: 100vw !important;
  }
}
@media (min-width: 1200px) {
  .w-xl-25 {
    width: 25% !important;
  }
  .h-xl-25 {
    height: 25% !important;
  }
  .w-xl-33 {
    width: 33.33% !important;
  }
  .h-xl-33 {
    height: 33.33% !important;
  }
  .w-xl-50 {
    width: 50% !important;
  }
  .h-xl-50 {
    height: 50% !important;
  }
  .w-xl-66 {
    width: 66.66% !important;
  }
  .h-xl-66 {
    height: 66.66% !important;
  }
  .w-xl-75 {
    width: 75% !important;
  }
  .h-xl-75 {
    height: 75% !important;
  }
  .w-xl-100 {
    width: 100% !important;
  }
  .h-xl-100 {
    height: 100% !important;
  }
  .w-xl-auto {
    width: auto !important;
  }
  .h-xl-auto {
    height: auto !important;
  }
  .w-xl-screen-v {
    width: 100vh !important;
  }
  .h-xl-screen-v {
    height: 100vh !important;
  }
  .w-xl-screen-h {
    width: 100vw !important;
  }
  .h-xl-screen-h {
    height: 100vw !important;
  }
}
@media (min-width: 1400px) {
  .w-xxl-25 {
    width: 25% !important;
  }
  .h-xxl-25 {
    height: 25% !important;
  }
  .w-xxl-33 {
    width: 33.33% !important;
  }
  .h-xxl-33 {
    height: 33.33% !important;
  }
  .w-xxl-50 {
    width: 50% !important;
  }
  .h-xxl-50 {
    height: 50% !important;
  }
  .w-xxl-66 {
    width: 66.66% !important;
  }
  .h-xxl-66 {
    height: 66.66% !important;
  }
  .w-xxl-75 {
    width: 75% !important;
  }
  .h-xxl-75 {
    height: 75% !important;
  }
  .w-xxl-100 {
    width: 100% !important;
  }
  .h-xxl-100 {
    height: 100% !important;
  }
  .w-xxl-auto {
    width: auto !important;
  }
  .h-xxl-auto {
    height: auto !important;
  }
  .w-xxl-screen-v {
    width: 100vh !important;
  }
  .h-xxl-screen-v {
    height: 100vh !important;
  }
  .w-xxl-screen-h {
    width: 100vw !important;
  }
  .h-xxl-screen-h {
    height: 100vw !important;
  }
}
/* --------------------------------------------
   Typography utilities
-------------------------------------------- */
.h1 {
  font-size: 2.5rem !important;
}

.h2 {
  font-size: 2rem !important;
}

.h3 {
  font-size: 1.75rem !important;
}

.h4 {
  font-size: 1.5rem !important;
}

.h5 {
  font-size: 1.25rem !important;
}

.h6 {
  font-size: 1rem !important;
}

.body {
  font-size: 1rem !important;
}

.small {
  font-size: 0.875rem !important;
}

.xs {
  font-size: 0.75rem !important;
}

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

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

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

.font-weight-light {
  font-weight: 300 !important;
}

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

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

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

.text-decoration-none {
  text-decoration: none !important;
}

.text-uppercase {
  text-transform: uppercase !important;
}

code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 0.95em;
  padding: 0.12em 0.35em;
  border-radius: 0.25rem;
  background: rgba(var(--primary-rgb), 0.1);
  border: 1px solid rgba(var(--primary-rgb), 0.14);
}

/* --------------------------------------------
   Border helpers
-------------------------------------------- */
.border {
  border: 1px solid var(--border-color) !important;
}

.border-top {
  border-top: 1px solid var(--border-color) !important;
}

.border-bottom {
  border-bottom: 1px solid var(--border-color) !important;
}

.border-left {
  border-left: 1px solid var(--border-color) !important;
}

.border-right {
  border-right: 1px solid var(--border-color) !important;
}

/* --------------------------------------------
   Radius helpers
-------------------------------------------- */
.rounded {
  border-radius: 0.5rem !important;
}

.rounded-sm {
  border-radius: 0.25rem !important;
}

.rounded-lg {
  border-radius: 1rem !important;
}

.rounded-pill {
  border-radius: 50rem !important;
}

.rounded-none {
  border-radius: 0 !important;
}

/* --------------------------------------------
   Elevation helpers
-------------------------------------------- */
.elevation-0 {
  box-shadow: none !important;
}

.elevation-1 {
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12) !important;
}

.elevation-2 {
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12) !important;
}

.elevation-4 {
  box-shadow: 0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12) !important;
}

.elevation-8 {
  box-shadow: 0 5px 5px -3px rgba(0, 0, 0, 0.2), 0 8px 10px 1px rgba(0, 0, 0, 0.14), 0 3px 14px 2px rgba(0, 0, 0, 0.12) !important;
}

.elevation-12 {
  box-shadow: 0 7px 8px -4px rgba(0, 0, 0, 0.2), 0 12px 17px 2px rgba(0, 0, 0, 0.14), 0 5px 22px 4px rgba(0, 0, 0, 0.12) !important;
}

.elevation-16 {
  box-shadow: 0 8px 10px -5px rgba(0, 0, 0, 0.2), 0 16px 24px 2px rgba(0, 0, 0, 0.14), 0 6px 30px 5px rgba(0, 0, 0, 0.12) !important;
}

.elevation-24 {
  box-shadow: 0 11px 15px -7px rgba(0, 0, 0, 0.2), 0 24px 38px 3px rgba(0, 0, 0, 0.14), 0 9px 46px 8px rgba(0, 0, 0, 0.12) !important;
}

/* --------------------------------------------
   Z-index utilities
-------------------------------------------- */
.z-deep {
  z-index: -1 !important;
}

.z-default {
  z-index: 1 !important;
}

.z-sticky {
  z-index: 100 !important;
}

.z-sidebar {
  z-index: 200 !important;
}

.z-header {
  z-index: 300 !important;
}

.z-backdrop {
  z-index: 400 !important;
}

.z-modal {
  z-index: 500 !important;
}

.z-dropdown {
  z-index: 600 !important;
}

.z-popover {
  z-index: 700 !important;
}

.z-tooltip {
  z-index: 800 !important;
}

.z-toast {
  z-index: 900 !important;
}

/* --------------------------------------------
   Visibility / overflow helpers
-------------------------------------------- */
.opacity-0 {
  opacity: 0 !important;
}

.opacity-50 {
  opacity: 0.5 !important;
}

.opacity-100 {
  opacity: 1 !important;
}

.overflow-hidden {
  overflow: hidden !important;
}

.overflow-auto {
  overflow: auto !important;
}

.cursor-pointer {
  cursor: pointer !important;
}

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

.is-hidden {
  display: none !important;
}

.lock-scroll {
  overflow: hidden !important;
}

/* --------------------------------------------
   Media helpers
-------------------------------------------- */
.img-fluid {
  max-width: 100%;
  height: auto;
}

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

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

.object-fill {
  -o-object-fit: fill !important;
     object-fit: fill !important;
}

.object-scale-down {
  -o-object-fit: scale-down !important;
     object-fit: scale-down !important;
}

.ratio-1x1 {
  position: relative;
  width: 100%;
}
.ratio-1x1::before {
  display: block;
  content: "";
  padding-top: 100%;
}
.ratio-1x1 > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ratio-4x3 {
  position: relative;
  width: 100%;
}
.ratio-4x3::before {
  display: block;
  content: "";
  padding-top: 75%;
}
.ratio-4x3 > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ratio-16x9 {
  position: relative;
  width: 100%;
}
.ratio-16x9::before {
  display: block;
  content: "";
  padding-top: 56.25%;
}
.ratio-16x9 > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ratio-21x9 {
  position: relative;
  width: 100%;
}
.ratio-21x9::before {
  display: block;
  content: "";
  padding-top: 42.85%;
}
.ratio-21x9 > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* --------------------------------------------
   Color utilities + Buttons + Alerts
-------------------------------------------- */
.text-gray {
  color: #6c757d !important;
}

.bg-gray {
  background-color: #6c757d !important;
}

.bg-gray-light {
  background-color: #f8f9fa !important;
}

.text-gray-50 {
  color: #fbfcfd !important;
}

.bg-gray-50 {
  background-color: #fbfcfd !important;
}

.text-gray-100 {
  color: #f8f9fa !important;
}

.bg-gray-100 {
  background-color: #f8f9fa !important;
}

.text-gray-200 {
  color: #e9ecef !important;
}

.bg-gray-200 {
  background-color: #e9ecef !important;
}

.text-gray-300 {
  color: #dee2e6 !important;
}

.bg-gray-300 {
  background-color: #dee2e6 !important;
}

.text-gray-400 {
  color: #ced4da !important;
}

.bg-gray-400 {
  background-color: #ced4da !important;
}

.text-gray-500 {
  color: #adb5bd !important;
}

.bg-gray-500 {
  background-color: #adb5bd !important;
}

.text-gray-600 {
  color: #6c757d !important;
}

.bg-gray-600 {
  background-color: #6c757d !important;
}

.text-gray-700 {
  color: #495057 !important;
}

.bg-gray-700 {
  background-color: #495057 !important;
}

.text-gray-800 {
  color: #343a40 !important;
}

.bg-gray-800 {
  background-color: #343a40 !important;
}

.text-gray-900 {
  color: #212529 !important;
}

.bg-gray-900 {
  background-color: #212529 !important;
}

.text-gray-950 {
  color: #121416 !important;
}

.bg-gray-950 {
  background-color: #121416 !important;
}

/* Solid button */
.btn-gray {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #6c757d;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-gray:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-gray:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-gray:focus {
  outline: none;
}
.btn-gray:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-gray:disabled, .btn-gray.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-gray-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #e9ecef;
  cursor: pointer;
  background-color: #f8f9fa;
  color: #343a40;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-gray-light:hover {
  background-color: #e9ecef;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-gray-light:active {
  background-color: #dee2e6;
  transform: translateY(0);
}
.btn-gray-light:focus {
  outline: none;
}
.btn-gray-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-gray-light:disabled, .btn-gray-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-gray {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #f8f9fa;
  color: #212529;
  border: 1px solid #e9ecef;
  margin-bottom: 1rem;
}

.text-blue {
  color: #0a58ca !important;
}

.bg-blue {
  background-color: #0a58ca !important;
}

.bg-blue-light {
  background-color: #e7f1ff !important;
}

.text-blue-50 {
  color: #f0f7ff !important;
}

.bg-blue-50 {
  background-color: #f0f7ff !important;
}

.text-blue-100 {
  color: #e7f1ff !important;
}

.bg-blue-100 {
  background-color: #e7f1ff !important;
}

.text-blue-200 {
  color: #cfe2ff !important;
}

.bg-blue-200 {
  background-color: #cfe2ff !important;
}

.text-blue-300 {
  color: #9ec5fe !important;
}

.bg-blue-300 {
  background-color: #9ec5fe !important;
}

.text-blue-400 {
  color: #6ea8fe !important;
}

.bg-blue-400 {
  background-color: #6ea8fe !important;
}

.text-blue-500 {
  color: #0d6efd !important;
}

.bg-blue-500 {
  background-color: #0d6efd !important;
}

.text-blue-600 {
  color: #0a58ca !important;
}

.bg-blue-600 {
  background-color: #0a58ca !important;
}

.text-blue-700 {
  color: #084298 !important;
}

.bg-blue-700 {
  background-color: #084298 !important;
}

.text-blue-800 {
  color: #052c65 !important;
}

.bg-blue-800 {
  background-color: #052c65 !important;
}

.text-blue-900 {
  color: #031633 !important;
}

.bg-blue-900 {
  background-color: #031633 !important;
}

.text-blue-950 {
  color: #020b1a !important;
}

.bg-blue-950 {
  background-color: #020b1a !important;
}

/* Solid button */
.btn-blue {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #0a58ca;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-blue:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-blue:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-blue:focus {
  outline: none;
}
.btn-blue:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-blue:disabled, .btn-blue.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-blue-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #cfe2ff;
  cursor: pointer;
  background-color: #e7f1ff;
  color: #052c65;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-blue-light:hover {
  background-color: #cfe2ff;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-blue-light:active {
  background-color: #9ec5fe;
  transform: translateY(0);
}
.btn-blue-light:focus {
  outline: none;
}
.btn-blue-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-blue-light:disabled, .btn-blue-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-blue {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #e7f1ff;
  color: #031633;
  border: 1px solid #cfe2ff;
  margin-bottom: 1rem;
}

.text-indigo {
  color: #7c3aed !important;
}

.bg-indigo {
  background-color: #7c3aed !important;
}

.bg-indigo-light {
  background-color: #ede9fe !important;
}

.text-indigo-50 {
  color: #f5f3ff !important;
}

.bg-indigo-50 {
  background-color: #f5f3ff !important;
}

.text-indigo-100 {
  color: #ede9fe !important;
}

.bg-indigo-100 {
  background-color: #ede9fe !important;
}

.text-indigo-200 {
  color: #ddd6fe !important;
}

.bg-indigo-200 {
  background-color: #ddd6fe !important;
}

.text-indigo-300 {
  color: #c4b5fd !important;
}

.bg-indigo-300 {
  background-color: #c4b5fd !important;
}

.text-indigo-400 {
  color: #a78bfa !important;
}

.bg-indigo-400 {
  background-color: #a78bfa !important;
}

.text-indigo-500 {
  color: #8b5cf6 !important;
}

.bg-indigo-500 {
  background-color: #8b5cf6 !important;
}

.text-indigo-600 {
  color: #7c3aed !important;
}

.bg-indigo-600 {
  background-color: #7c3aed !important;
}

.text-indigo-700 {
  color: #6d28d9 !important;
}

.bg-indigo-700 {
  background-color: #6d28d9 !important;
}

.text-indigo-800 {
  color: #5b21b6 !important;
}

.bg-indigo-800 {
  background-color: #5b21b6 !important;
}

.text-indigo-900 {
  color: #4c1d95 !important;
}

.bg-indigo-900 {
  background-color: #4c1d95 !important;
}

.text-indigo-950 {
  color: #2e1065 !important;
}

.bg-indigo-950 {
  background-color: #2e1065 !important;
}

/* Solid button */
.btn-indigo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #7c3aed;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-indigo:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-indigo:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-indigo:focus {
  outline: none;
}
.btn-indigo:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-indigo:disabled, .btn-indigo.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-indigo-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #ddd6fe;
  cursor: pointer;
  background-color: #ede9fe;
  color: #5b21b6;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-indigo-light:hover {
  background-color: #ddd6fe;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-indigo-light:active {
  background-color: #c4b5fd;
  transform: translateY(0);
}
.btn-indigo-light:focus {
  outline: none;
}
.btn-indigo-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-indigo-light:disabled, .btn-indigo-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-indigo {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #ede9fe;
  color: #4c1d95;
  border: 1px solid #ddd6fe;
  margin-bottom: 1rem;
}

.text-purple {
  color: #9333ea !important;
}

.bg-purple {
  background-color: #9333ea !important;
}

.bg-purple-light {
  background-color: #f3e8ff !important;
}

.text-purple-50 {
  color: #faf5ff !important;
}

.bg-purple-50 {
  background-color: #faf5ff !important;
}

.text-purple-100 {
  color: #f3e8ff !important;
}

.bg-purple-100 {
  background-color: #f3e8ff !important;
}

.text-purple-200 {
  color: #e9d5ff !important;
}

.bg-purple-200 {
  background-color: #e9d5ff !important;
}

.text-purple-300 {
  color: #d8b4fe !important;
}

.bg-purple-300 {
  background-color: #d8b4fe !important;
}

.text-purple-400 {
  color: #c084fc !important;
}

.bg-purple-400 {
  background-color: #c084fc !important;
}

.text-purple-500 {
  color: #a855f7 !important;
}

.bg-purple-500 {
  background-color: #a855f7 !important;
}

.text-purple-600 {
  color: #9333ea !important;
}

.bg-purple-600 {
  background-color: #9333ea !important;
}

.text-purple-700 {
  color: #7e22ce !important;
}

.bg-purple-700 {
  background-color: #7e22ce !important;
}

.text-purple-800 {
  color: #6b21a8 !important;
}

.bg-purple-800 {
  background-color: #6b21a8 !important;
}

.text-purple-900 {
  color: #581c87 !important;
}

.bg-purple-900 {
  background-color: #581c87 !important;
}

.text-purple-950 {
  color: #3b0764 !important;
}

.bg-purple-950 {
  background-color: #3b0764 !important;
}

/* Solid button */
.btn-purple {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #9333ea;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-purple:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-purple:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-purple:focus {
  outline: none;
}
.btn-purple:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-purple:disabled, .btn-purple.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-purple-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #e9d5ff;
  cursor: pointer;
  background-color: #f3e8ff;
  color: #6b21a8;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-purple-light:hover {
  background-color: #e9d5ff;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-purple-light:active {
  background-color: #d8b4fe;
  transform: translateY(0);
}
.btn-purple-light:focus {
  outline: none;
}
.btn-purple-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-purple-light:disabled, .btn-purple-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-purple {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #f3e8ff;
  color: #581c87;
  border: 1px solid #e9d5ff;
  margin-bottom: 1rem;
}

.text-pink {
  color: #db2777 !important;
}

.bg-pink {
  background-color: #db2777 !important;
}

.bg-pink-light {
  background-color: #fce7f3 !important;
}

.text-pink-50 {
  color: #fdf2f8 !important;
}

.bg-pink-50 {
  background-color: #fdf2f8 !important;
}

.text-pink-100 {
  color: #fce7f3 !important;
}

.bg-pink-100 {
  background-color: #fce7f3 !important;
}

.text-pink-200 {
  color: #fbcfe8 !important;
}

.bg-pink-200 {
  background-color: #fbcfe8 !important;
}

.text-pink-300 {
  color: #f9a8d4 !important;
}

.bg-pink-300 {
  background-color: #f9a8d4 !important;
}

.text-pink-400 {
  color: #f472b6 !important;
}

.bg-pink-400 {
  background-color: #f472b6 !important;
}

.text-pink-500 {
  color: #ec4899 !important;
}

.bg-pink-500 {
  background-color: #ec4899 !important;
}

.text-pink-600 {
  color: #db2777 !important;
}

.bg-pink-600 {
  background-color: #db2777 !important;
}

.text-pink-700 {
  color: #be185d !important;
}

.bg-pink-700 {
  background-color: #be185d !important;
}

.text-pink-800 {
  color: #9d174d !important;
}

.bg-pink-800 {
  background-color: #9d174d !important;
}

.text-pink-900 {
  color: #831843 !important;
}

.bg-pink-900 {
  background-color: #831843 !important;
}

.text-pink-950 {
  color: #500724 !important;
}

.bg-pink-950 {
  background-color: #500724 !important;
}

/* Solid button */
.btn-pink {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #db2777;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-pink:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-pink:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-pink:focus {
  outline: none;
}
.btn-pink:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-pink:disabled, .btn-pink.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-pink-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #fbcfe8;
  cursor: pointer;
  background-color: #fce7f3;
  color: #9d174d;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-pink-light:hover {
  background-color: #fbcfe8;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-pink-light:active {
  background-color: #f9a8d4;
  transform: translateY(0);
}
.btn-pink-light:focus {
  outline: none;
}
.btn-pink-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-pink-light:disabled, .btn-pink-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-pink {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #fce7f3;
  color: #831843;
  border: 1px solid #fbcfe8;
  margin-bottom: 1rem;
}

.text-red {
  color: #dc2626 !important;
}

.bg-red {
  background-color: #dc2626 !important;
}

.bg-red-light {
  background-color: #fee2e2 !important;
}

.text-red-50 {
  color: #fef2f2 !important;
}

.bg-red-50 {
  background-color: #fef2f2 !important;
}

.text-red-100 {
  color: #fee2e2 !important;
}

.bg-red-100 {
  background-color: #fee2e2 !important;
}

.text-red-200 {
  color: #fecaca !important;
}

.bg-red-200 {
  background-color: #fecaca !important;
}

.text-red-300 {
  color: #fca5a5 !important;
}

.bg-red-300 {
  background-color: #fca5a5 !important;
}

.text-red-400 {
  color: #f87171 !important;
}

.bg-red-400 {
  background-color: #f87171 !important;
}

.text-red-500 {
  color: #ef4444 !important;
}

.bg-red-500 {
  background-color: #ef4444 !important;
}

.text-red-600 {
  color: #dc2626 !important;
}

.bg-red-600 {
  background-color: #dc2626 !important;
}

.text-red-700 {
  color: #b91c1c !important;
}

.bg-red-700 {
  background-color: #b91c1c !important;
}

.text-red-800 {
  color: #991b1b !important;
}

.bg-red-800 {
  background-color: #991b1b !important;
}

.text-red-900 {
  color: #7f1d1d !important;
}

.bg-red-900 {
  background-color: #7f1d1d !important;
}

.text-red-950 {
  color: #450a0a !important;
}

.bg-red-950 {
  background-color: #450a0a !important;
}

/* Solid button */
.btn-red {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #dc2626;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-red:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-red:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-red:focus {
  outline: none;
}
.btn-red:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-red:disabled, .btn-red.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-red-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #fecaca;
  cursor: pointer;
  background-color: #fee2e2;
  color: #991b1b;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-red-light:hover {
  background-color: #fecaca;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-red-light:active {
  background-color: #fca5a5;
  transform: translateY(0);
}
.btn-red-light:focus {
  outline: none;
}
.btn-red-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-red-light:disabled, .btn-red-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-red {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #fee2e2;
  color: #7f1d1d;
  border: 1px solid #fecaca;
  margin-bottom: 1rem;
}

.text-orange {
  color: #ea580c !important;
}

.bg-orange {
  background-color: #ea580c !important;
}

.bg-orange-light {
  background-color: #ffedd5 !important;
}

.text-orange-50 {
  color: #fff7ed !important;
}

.bg-orange-50 {
  background-color: #fff7ed !important;
}

.text-orange-100 {
  color: #ffedd5 !important;
}

.bg-orange-100 {
  background-color: #ffedd5 !important;
}

.text-orange-200 {
  color: #fed7aa !important;
}

.bg-orange-200 {
  background-color: #fed7aa !important;
}

.text-orange-300 {
  color: #fdba74 !important;
}

.bg-orange-300 {
  background-color: #fdba74 !important;
}

.text-orange-400 {
  color: #fb923c !important;
}

.bg-orange-400 {
  background-color: #fb923c !important;
}

.text-orange-500 {
  color: #f97316 !important;
}

.bg-orange-500 {
  background-color: #f97316 !important;
}

.text-orange-600 {
  color: #ea580c !important;
}

.bg-orange-600 {
  background-color: #ea580c !important;
}

.text-orange-700 {
  color: #c2410c !important;
}

.bg-orange-700 {
  background-color: #c2410c !important;
}

.text-orange-800 {
  color: #9a3412 !important;
}

.bg-orange-800 {
  background-color: #9a3412 !important;
}

.text-orange-900 {
  color: #7c2d12 !important;
}

.bg-orange-900 {
  background-color: #7c2d12 !important;
}

.text-orange-950 {
  color: #431407 !important;
}

.bg-orange-950 {
  background-color: #431407 !important;
}

/* Solid button */
.btn-orange {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #ea580c;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-orange:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-orange:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-orange:focus {
  outline: none;
}
.btn-orange:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-orange:disabled, .btn-orange.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-orange-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #fed7aa;
  cursor: pointer;
  background-color: #ffedd5;
  color: #9a3412;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-orange-light:hover {
  background-color: #fed7aa;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-orange-light:active {
  background-color: #fdba74;
  transform: translateY(0);
}
.btn-orange-light:focus {
  outline: none;
}
.btn-orange-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-orange-light:disabled, .btn-orange-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-orange {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #ffedd5;
  color: #7c2d12;
  border: 1px solid #fed7aa;
  margin-bottom: 1rem;
}

.text-yellow {
  color: #ca8a04 !important;
}

.bg-yellow {
  background-color: #ca8a04 !important;
}

.bg-yellow-light {
  background-color: #fef9c3 !important;
}

.text-yellow-50 {
  color: #fefce8 !important;
}

.bg-yellow-50 {
  background-color: #fefce8 !important;
}

.text-yellow-100 {
  color: #fef9c3 !important;
}

.bg-yellow-100 {
  background-color: #fef9c3 !important;
}

.text-yellow-200 {
  color: #fef08a !important;
}

.bg-yellow-200 {
  background-color: #fef08a !important;
}

.text-yellow-300 {
  color: #fde047 !important;
}

.bg-yellow-300 {
  background-color: #fde047 !important;
}

.text-yellow-400 {
  color: #facc15 !important;
}

.bg-yellow-400 {
  background-color: #facc15 !important;
}

.text-yellow-500 {
  color: #eab308 !important;
}

.bg-yellow-500 {
  background-color: #eab308 !important;
}

.text-yellow-600 {
  color: #ca8a04 !important;
}

.bg-yellow-600 {
  background-color: #ca8a04 !important;
}

.text-yellow-700 {
  color: #a16207 !important;
}

.bg-yellow-700 {
  background-color: #a16207 !important;
}

.text-yellow-800 {
  color: #854d0e !important;
}

.bg-yellow-800 {
  background-color: #854d0e !important;
}

.text-yellow-900 {
  color: #713f12 !important;
}

.bg-yellow-900 {
  background-color: #713f12 !important;
}

.text-yellow-950 {
  color: #422006 !important;
}

.bg-yellow-950 {
  background-color: #422006 !important;
}

/* Solid button */
.btn-yellow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #ca8a04;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-yellow:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-yellow:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-yellow:focus {
  outline: none;
}
.btn-yellow:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-yellow:disabled, .btn-yellow.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-yellow-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #fef08a;
  cursor: pointer;
  background-color: #fef9c3;
  color: #854d0e;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-yellow-light:hover {
  background-color: #fef08a;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-yellow-light:active {
  background-color: #fde047;
  transform: translateY(0);
}
.btn-yellow-light:focus {
  outline: none;
}
.btn-yellow-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-yellow-light:disabled, .btn-yellow-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-yellow {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #fef9c3;
  color: #713f12;
  border: 1px solid #fef08a;
  margin-bottom: 1rem;
}

.text-green {
  color: #16a34a !important;
}

.bg-green {
  background-color: #16a34a !important;
}

.bg-green-light {
  background-color: #dcfce7 !important;
}

.text-green-50 {
  color: #f0fdf4 !important;
}

.bg-green-50 {
  background-color: #f0fdf4 !important;
}

.text-green-100 {
  color: #dcfce7 !important;
}

.bg-green-100 {
  background-color: #dcfce7 !important;
}

.text-green-200 {
  color: #bbf7d0 !important;
}

.bg-green-200 {
  background-color: #bbf7d0 !important;
}

.text-green-300 {
  color: #86efac !important;
}

.bg-green-300 {
  background-color: #86efac !important;
}

.text-green-400 {
  color: #4ade80 !important;
}

.bg-green-400 {
  background-color: #4ade80 !important;
}

.text-green-500 {
  color: #22c55e !important;
}

.bg-green-500 {
  background-color: #22c55e !important;
}

.text-green-600 {
  color: #16a34a !important;
}

.bg-green-600 {
  background-color: #16a34a !important;
}

.text-green-700 {
  color: #15803d !important;
}

.bg-green-700 {
  background-color: #15803d !important;
}

.text-green-800 {
  color: #166534 !important;
}

.bg-green-800 {
  background-color: #166534 !important;
}

.text-green-900 {
  color: #14532d !important;
}

.bg-green-900 {
  background-color: #14532d !important;
}

.text-green-950 {
  color: #052e16 !important;
}

.bg-green-950 {
  background-color: #052e16 !important;
}

/* Solid button */
.btn-green {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #16a34a;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-green:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-green:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-green:focus {
  outline: none;
}
.btn-green:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-green:disabled, .btn-green.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-green-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #bbf7d0;
  cursor: pointer;
  background-color: #dcfce7;
  color: #166534;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-green-light:hover {
  background-color: #bbf7d0;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-green-light:active {
  background-color: #86efac;
  transform: translateY(0);
}
.btn-green-light:focus {
  outline: none;
}
.btn-green-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-green-light:disabled, .btn-green-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-green {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #dcfce7;
  color: #14532d;
  border: 1px solid #bbf7d0;
  margin-bottom: 1rem;
}

.text-emerald {
  color: #059669 !important;
}

.bg-emerald {
  background-color: #059669 !important;
}

.bg-emerald-light {
  background-color: #d1fae5 !important;
}

.text-emerald-50 {
  color: #ecfdf5 !important;
}

.bg-emerald-50 {
  background-color: #ecfdf5 !important;
}

.text-emerald-100 {
  color: #d1fae5 !important;
}

.bg-emerald-100 {
  background-color: #d1fae5 !important;
}

.text-emerald-200 {
  color: #a7f3d0 !important;
}

.bg-emerald-200 {
  background-color: #a7f3d0 !important;
}

.text-emerald-300 {
  color: #6ee7b7 !important;
}

.bg-emerald-300 {
  background-color: #6ee7b7 !important;
}

.text-emerald-400 {
  color: #34d399 !important;
}

.bg-emerald-400 {
  background-color: #34d399 !important;
}

.text-emerald-500 {
  color: #10b981 !important;
}

.bg-emerald-500 {
  background-color: #10b981 !important;
}

.text-emerald-600 {
  color: #059669 !important;
}

.bg-emerald-600 {
  background-color: #059669 !important;
}

.text-emerald-700 {
  color: #047857 !important;
}

.bg-emerald-700 {
  background-color: #047857 !important;
}

.text-emerald-800 {
  color: #065f46 !important;
}

.bg-emerald-800 {
  background-color: #065f46 !important;
}

.text-emerald-900 {
  color: #064e3b !important;
}

.bg-emerald-900 {
  background-color: #064e3b !important;
}

.text-emerald-950 {
  color: #022c22 !important;
}

.bg-emerald-950 {
  background-color: #022c22 !important;
}

/* Solid button */
.btn-emerald {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #059669;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-emerald:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-emerald:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-emerald:focus {
  outline: none;
}
.btn-emerald:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-emerald:disabled, .btn-emerald.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-emerald-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #a7f3d0;
  cursor: pointer;
  background-color: #d1fae5;
  color: #065f46;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-emerald-light:hover {
  background-color: #a7f3d0;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-emerald-light:active {
  background-color: #6ee7b7;
  transform: translateY(0);
}
.btn-emerald-light:focus {
  outline: none;
}
.btn-emerald-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-emerald-light:disabled, .btn-emerald-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-emerald {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #d1fae5;
  color: #064e3b;
  border: 1px solid #a7f3d0;
  margin-bottom: 1rem;
}

.text-teal {
  color: #0d9488 !important;
}

.bg-teal {
  background-color: #0d9488 !important;
}

.bg-teal-light {
  background-color: #ccfbf1 !important;
}

.text-teal-50 {
  color: #f0fdfa !important;
}

.bg-teal-50 {
  background-color: #f0fdfa !important;
}

.text-teal-100 {
  color: #ccfbf1 !important;
}

.bg-teal-100 {
  background-color: #ccfbf1 !important;
}

.text-teal-200 {
  color: #99f6e4 !important;
}

.bg-teal-200 {
  background-color: #99f6e4 !important;
}

.text-teal-300 {
  color: #5eead4 !important;
}

.bg-teal-300 {
  background-color: #5eead4 !important;
}

.text-teal-400 {
  color: #2dd4bf !important;
}

.bg-teal-400 {
  background-color: #2dd4bf !important;
}

.text-teal-500 {
  color: #14b8a6 !important;
}

.bg-teal-500 {
  background-color: #14b8a6 !important;
}

.text-teal-600 {
  color: #0d9488 !important;
}

.bg-teal-600 {
  background-color: #0d9488 !important;
}

.text-teal-700 {
  color: #0f766e !important;
}

.bg-teal-700 {
  background-color: #0f766e !important;
}

.text-teal-800 {
  color: #115e59 !important;
}

.bg-teal-800 {
  background-color: #115e59 !important;
}

.text-teal-900 {
  color: #134e4a !important;
}

.bg-teal-900 {
  background-color: #134e4a !important;
}

.text-teal-950 {
  color: #042f2e !important;
}

.bg-teal-950 {
  background-color: #042f2e !important;
}

/* Solid button */
.btn-teal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #0d9488;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-teal:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-teal:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-teal:focus {
  outline: none;
}
.btn-teal:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-teal:disabled, .btn-teal.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-teal-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #99f6e4;
  cursor: pointer;
  background-color: #ccfbf1;
  color: #115e59;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-teal-light:hover {
  background-color: #99f6e4;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-teal-light:active {
  background-color: #5eead4;
  transform: translateY(0);
}
.btn-teal-light:focus {
  outline: none;
}
.btn-teal-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-teal-light:disabled, .btn-teal-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-teal {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #ccfbf1;
  color: #134e4a;
  border: 1px solid #99f6e4;
  margin-bottom: 1rem;
}

.text-cyan {
  color: #0891b2 !important;
}

.bg-cyan {
  background-color: #0891b2 !important;
}

.bg-cyan-light {
  background-color: #cffafe !important;
}

.text-cyan-50 {
  color: #ecfeff !important;
}

.bg-cyan-50 {
  background-color: #ecfeff !important;
}

.text-cyan-100 {
  color: #cffafe !important;
}

.bg-cyan-100 {
  background-color: #cffafe !important;
}

.text-cyan-200 {
  color: #a5f3fc !important;
}

.bg-cyan-200 {
  background-color: #a5f3fc !important;
}

.text-cyan-300 {
  color: #67e8f9 !important;
}

.bg-cyan-300 {
  background-color: #67e8f9 !important;
}

.text-cyan-400 {
  color: #22d3ee !important;
}

.bg-cyan-400 {
  background-color: #22d3ee !important;
}

.text-cyan-500 {
  color: #06b6d4 !important;
}

.bg-cyan-500 {
  background-color: #06b6d4 !important;
}

.text-cyan-600 {
  color: #0891b2 !important;
}

.bg-cyan-600 {
  background-color: #0891b2 !important;
}

.text-cyan-700 {
  color: #0e7490 !important;
}

.bg-cyan-700 {
  background-color: #0e7490 !important;
}

.text-cyan-800 {
  color: #155e75 !important;
}

.bg-cyan-800 {
  background-color: #155e75 !important;
}

.text-cyan-900 {
  color: #164e63 !important;
}

.bg-cyan-900 {
  background-color: #164e63 !important;
}

.text-cyan-950 {
  color: #083344 !important;
}

.bg-cyan-950 {
  background-color: #083344 !important;
}

/* Solid button */
.btn-cyan {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid transparent;
  cursor: pointer;
  background-color: #0891b2;
  color: #ffffff;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1), filter 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-cyan:hover {
  filter: brightness(95%);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}
.btn-cyan:active {
  filter: brightness(90%);
  transform: translateY(0);
}
.btn-cyan:focus {
  outline: none;
}
.btn-cyan:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
}
.btn-cyan:disabled, .btn-cyan.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: none;
}

/* Light button */
.btn-cyan-light {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-weight: 500;
  border-radius: 0.5rem;
  border: 1px solid #a5f3fc;
  cursor: pointer;
  background-color: #cffafe;
  color: #155e75;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-cyan-light:hover {
  background-color: #a5f3fc;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-1px);
}
.btn-cyan-light:active {
  background-color: #67e8f9;
  transform: translateY(0);
}
.btn-cyan-light:focus {
  outline: none;
}
.btn-cyan-light:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35), 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}
.btn-cyan-light:disabled, .btn-cyan-light.is-disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
}

/* Alerts */
.alert-cyan {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: #cffafe;
  color: #164e63;
  border: 1px solid #a5f3fc;
  margin-bottom: 1rem;
}

/* Button size modifiers */
.btn-sm {
  padding: 0.3571428571rem 0.7142857143rem !important;
  font-size: 0.875rem !important;
  border-radius: 0.25rem !important;
}

.btn-lg {
  padding: 1rem 1.5rem !important;
  font-size: 1rem !important;
  border-radius: 1rem !important;
}

/* --------------------------------------------
   Cards / Surfaces
-------------------------------------------- */
.card {
  background-color: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: 0.5rem;
  padding: 1.5rem;
  box-shadow: 0 2px 1px -1px rgba(0, 0, 0, 0.2), 0 1px 1px 0 rgba(0, 0, 0, 0.14), 0 1px 3px 0 rgba(0, 0, 0, 0.12);
}

.card.hoverable {
  transition: box-shadow 400ms cubic-bezier(0.4, 0, 0.2, 1), transform 400ms cubic-bezier(0.4, 0, 0.2, 1);
}
.card.hoverable:hover {
  box-shadow: 0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}

.card-soft {
  background-color: var(--bg-surface);
  border: 1px solid var(--border-color);
}

/* --------------------------------------------
   Forms (inputs/selects/textarea/checkbox/radio)
-------------------------------------------- */
.form-group {
  margin-bottom: 1rem;
}

.label {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-muted);
}

.input {
  width: 100%;
  height: 2.5rem;
  padding: 0.5rem 1rem;
  background-color: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 0.25rem;
  color: var(--text-main);
  transition: border-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 150ms cubic-bezier(0.4, 0, 0.2, 1), background-color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.input:focus {
  outline: none;
  border-color: var(--primary);
}
.input:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35);
}
.input::-moz-placeholder {
  color: var(--text-light);
}
.input::placeholder {
  color: var(--text-light);
}
.input:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

.input-sm {
  width: 100%;
  height: 2rem;
  padding: 0.5rem 1rem;
  background-color: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 0.25rem;
  color: var(--text-main);
  transition: border-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 150ms cubic-bezier(0.4, 0, 0.2, 1), background-color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.input-sm:focus {
  outline: none;
  border-color: var(--primary);
}
.input-sm:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35);
}
.input-sm::-moz-placeholder {
  color: var(--text-light);
}
.input-sm::placeholder {
  color: var(--text-light);
}
.input-sm:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}
.input-sm {
  font-size: 0.875rem;
}

.input-lg {
  width: 100%;
  height: 3.25rem;
  padding: 0.5rem 1rem;
  background-color: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 0.25rem;
  color: var(--text-main);
  transition: border-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 150ms cubic-bezier(0.4, 0, 0.2, 1), background-color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.input-lg:focus {
  outline: none;
  border-color: var(--primary);
}
.input-lg:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35);
}
.input-lg::-moz-placeholder {
  color: var(--text-light);
}
.input-lg::placeholder {
  color: var(--text-light);
}
.input-lg:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}
.input-lg {
  font-size: 1rem;
}

.textarea {
  width: 100%;
  height: 3.25rem;
  padding: 0.5rem 1rem;
  background-color: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 0.25rem;
  color: var(--text-main);
  transition: border-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 150ms cubic-bezier(0.4, 0, 0.2, 1), background-color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.textarea:focus {
  outline: none;
  border-color: var(--primary);
}
.textarea:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35);
}
.textarea::-moz-placeholder {
  color: var(--text-light);
}
.textarea::placeholder {
  color: var(--text-light);
}
.textarea:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}
.textarea {
  height: auto;
  min-height: 120px;
  resize: vertical;
}

.select {
  width: 100%;
  height: 2.5rem;
  padding: 0.5rem 1rem;
  background-color: var(--bg-surface);
  border: 1px solid var(--border-color);
  border-radius: 0.25rem;
  color: var(--text-main);
  transition: border-color 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 150ms cubic-bezier(0.4, 0, 0.2, 1), background-color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.select:focus {
  outline: none;
  border-color: var(--primary);
}
.select:focus-visible {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35);
}
.select::-moz-placeholder {
  color: var(--text-light);
}
.select::placeholder {
  color: var(--text-light);
}
.select:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}
.select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  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 5l6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 16px 12px;
}

[data-theme=dark] .select {
  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='%23cbd5e1' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
}

.input-group {
  display: flex;
  align-items: stretch;
}
.input-group .input, .input-group .select {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.input-group [class^=btn-], .input-group .btn {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  white-space: nowrap;
}

/* Checkbox / radio */
.check {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  color: var(--text-main);
}
.check input {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--primary);
}
.check input:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35);
  border-radius: 0.25rem;
}
.check .check-label {
  color: var(--text-muted);
}

/* --------------------------------------------
   Tables (token-driven)
-------------------------------------------- */
.table-wrap {
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: inherit;
}

.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  margin: 0;
}
.table th, .table td {
  padding: 1rem 1rem;
  text-align: left;
  vertical-align: middle;
  border-bottom: 1px solid var(--border-color);
}
.table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--table-header-bg);
  color: var(--text-muted);
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0.02em;
  font-size: 0.875rem;
  border-bottom: 1px solid var(--border-color);
}
.table thead th:first-child {
  border-top-left-radius: 0.5rem;
}
.table thead th:last-child {
  border-top-right-radius: 0.5rem;
}
.table tbody tr {
  background: transparent;
  transition: background-color 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.table.striped tbody tr:nth-of-type(odd) {
  background: var(--table-striped-bg);
}
.table.hover tbody tr:hover {
  background: var(--table-hover-bg);
}
.table.table-sm th, .table.table-sm td {
  padding: 0.7142857143rem 0.7142857143rem;
}
.table.table-sm thead th {
  font-size: 0.75rem;
}

/* --------------------------------------------
   Scrollbar
-------------------------------------------- */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: #f8f9fa;
}

::-webkit-scrollbar-thumb {
  background: #dee2e6;
  border-radius: 50rem;
}
::-webkit-scrollbar-thumb:hover {
  background: #ced4da;
}

/* --------------------------------------------
   Badges
-------------------------------------------- */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.25em 0.6em;
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: 50rem;
  line-height: 1;
  white-space: nowrap;
}

.badge-gray {
  background-color: #f8f9fa;
  color: #343a40;
  border: 1px solid #e9ecef;
}
.badge-gray.badge-solid {
  background-color: #6c757d;
  color: #ffffff;
  border-color: transparent;
}

.badge-blue {
  background-color: #e7f1ff;
  color: #052c65;
  border: 1px solid #cfe2ff;
}
.badge-blue.badge-solid {
  background-color: #0a58ca;
  color: #ffffff;
  border-color: transparent;
}

.badge-indigo {
  background-color: #ede9fe;
  color: #5b21b6;
  border: 1px solid #ddd6fe;
}
.badge-indigo.badge-solid {
  background-color: #7c3aed;
  color: #ffffff;
  border-color: transparent;
}

.badge-purple {
  background-color: #f3e8ff;
  color: #6b21a8;
  border: 1px solid #e9d5ff;
}
.badge-purple.badge-solid {
  background-color: #9333ea;
  color: #ffffff;
  border-color: transparent;
}

.badge-pink {
  background-color: #fce7f3;
  color: #9d174d;
  border: 1px solid #fbcfe8;
}
.badge-pink.badge-solid {
  background-color: #db2777;
  color: #ffffff;
  border-color: transparent;
}

.badge-red {
  background-color: #fee2e2;
  color: #991b1b;
  border: 1px solid #fecaca;
}
.badge-red.badge-solid {
  background-color: #dc2626;
  color: #ffffff;
  border-color: transparent;
}

.badge-orange {
  background-color: #ffedd5;
  color: #9a3412;
  border: 1px solid #fed7aa;
}
.badge-orange.badge-solid {
  background-color: #ea580c;
  color: #ffffff;
  border-color: transparent;
}

.badge-yellow {
  background-color: #fef9c3;
  color: #854d0e;
  border: 1px solid #fef08a;
}
.badge-yellow.badge-solid {
  background-color: #ca8a04;
  color: #ffffff;
  border-color: transparent;
}

.badge-green {
  background-color: #dcfce7;
  color: #166534;
  border: 1px solid #bbf7d0;
}
.badge-green.badge-solid {
  background-color: #16a34a;
  color: #ffffff;
  border-color: transparent;
}

.badge-emerald {
  background-color: #d1fae5;
  color: #065f46;
  border: 1px solid #a7f3d0;
}
.badge-emerald.badge-solid {
  background-color: #059669;
  color: #ffffff;
  border-color: transparent;
}

.badge-teal {
  background-color: #ccfbf1;
  color: #115e59;
  border: 1px solid #99f6e4;
}
.badge-teal.badge-solid {
  background-color: #0d9488;
  color: #ffffff;
  border-color: transparent;
}

.badge-cyan {
  background-color: #cffafe;
  color: #155e75;
  border: 1px solid #a5f3fc;
}
.badge-cyan.badge-solid {
  background-color: #0891b2;
  color: #ffffff;
  border-color: transparent;
}

/* --------------------------------------------
   Chips (component)
-------------------------------------------- */
.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.65rem;
  border-radius: 50rem;
  border: 1px solid var(--border-color);
  background: var(--bg-surface);
  color: var(--text-muted);
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  transition: transform 150ms cubic-bezier(0.4, 0, 0.2, 1), box-shadow 250ms cubic-bezier(0.4, 0, 0.2, 1), background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.chip:hover {
  transform: translateY(-1px);
  box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
  color: var(--text-main);
}
.chip.is-active {
  background: rgba(var(--primary-rgb), 0.12);
  border-color: rgba(var(--primary-rgb), 0.18);
  color: var(--text-main);
}

/* --------------------------------------------
   Progress (component)
-------------------------------------------- */
.progress {
  position: relative;
  display: block;
  width: 100%;
  height: 10px;
  overflow: hidden;
  border: 1px solid var(--border-color);
  border-radius: 50rem;
  background: var(--bg-surface);
}
.progress.progress-sm {
  height: 6px;
}
.progress.progress-lg {
  height: 14px;
}
.progress.is-soft {
  background: rgba(var(--primary-rgb), 0.06);
  border-color: rgba(var(--primary-rgb), 0.1);
}
[data-theme=light] .progress.is-soft {
  background: rgba(var(--primary-rgb), 0.08);
  border-color: rgba(var(--primary-rgb), 0.12);
}
.progress.is-striped .progress-bar {
  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.14) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.14) 50%, rgba(255, 255, 255, 0.14) 75%, transparent 75%, transparent);
  background-size: 1rem 1rem;
}
.progress.is-animated .progress-bar {
  animation: vor-progress-stripes 0.9s linear infinite;
}
.progress-bar {
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: var(--primary);
  transition: width 400ms cubic-bezier(0.4, 0, 0.2, 1), background-color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.progress-bar.soft {
  background: rgba(var(--primary-rgb), 0.55);
}
.progress-bar.solid {
  background: var(--primary);
}
.progress-bar.success {
  background: var(--success);
}
.progress-bar.info {
  background: var(--info);
}
.progress-bar.warning {
  background: var(--warning);
}
.progress-bar.danger {
  background: var(--danger);
}
.progress-bar.gray {
  background: var(--text-light);
}
.progress-bar.teal {
  background: var(--primary);
}
.progress-bar.orange {
  background: var(--accent);
}
.progress-bar.success-soft {
  background: rgba(34, 197, 94, 0.55);
}
.progress-bar.info-soft {
  background: rgba(59, 130, 246, 0.55);
}
.progress-bar.warning-soft {
  background: rgba(249, 115, 22, 0.55);
}
.progress-bar.danger-soft {
  background: rgba(239, 68, 68, 0.55);
}
.progress-bar.gray-soft {
  background: rgba(148, 163, 184, 0.55);
}
.progress-bar.is-0 {
  width: 0%;
}
.progress-bar.is-1 {
  width: 1%;
}
.progress-bar.is-2 {
  width: 2%;
}
.progress-bar.is-3 {
  width: 3%;
}
.progress-bar.is-4 {
  width: 4%;
}
.progress-bar.is-5 {
  width: 5%;
}
.progress-bar.is-6 {
  width: 6%;
}
.progress-bar.is-7 {
  width: 7%;
}
.progress-bar.is-8 {
  width: 8%;
}
.progress-bar.is-9 {
  width: 9%;
}
.progress-bar.is-10 {
  width: 10%;
}
.progress-bar.is-11 {
  width: 11%;
}
.progress-bar.is-12 {
  width: 12%;
}
.progress-bar.is-13 {
  width: 13%;
}
.progress-bar.is-14 {
  width: 14%;
}
.progress-bar.is-15 {
  width: 15%;
}
.progress-bar.is-16 {
  width: 16%;
}
.progress-bar.is-17 {
  width: 17%;
}
.progress-bar.is-18 {
  width: 18%;
}
.progress-bar.is-19 {
  width: 19%;
}
.progress-bar.is-20 {
  width: 20%;
}
.progress-bar.is-21 {
  width: 21%;
}
.progress-bar.is-22 {
  width: 22%;
}
.progress-bar.is-23 {
  width: 23%;
}
.progress-bar.is-24 {
  width: 24%;
}
.progress-bar.is-25 {
  width: 25%;
}
.progress-bar.is-26 {
  width: 26%;
}
.progress-bar.is-27 {
  width: 27%;
}
.progress-bar.is-28 {
  width: 28%;
}
.progress-bar.is-29 {
  width: 29%;
}
.progress-bar.is-30 {
  width: 30%;
}
.progress-bar.is-31 {
  width: 31%;
}
.progress-bar.is-32 {
  width: 32%;
}
.progress-bar.is-33 {
  width: 33%;
}
.progress-bar.is-34 {
  width: 34%;
}
.progress-bar.is-35 {
  width: 35%;
}
.progress-bar.is-36 {
  width: 36%;
}
.progress-bar.is-37 {
  width: 37%;
}
.progress-bar.is-38 {
  width: 38%;
}
.progress-bar.is-39 {
  width: 39%;
}
.progress-bar.is-40 {
  width: 40%;
}
.progress-bar.is-41 {
  width: 41%;
}
.progress-bar.is-42 {
  width: 42%;
}
.progress-bar.is-43 {
  width: 43%;
}
.progress-bar.is-44 {
  width: 44%;
}
.progress-bar.is-45 {
  width: 45%;
}
.progress-bar.is-46 {
  width: 46%;
}
.progress-bar.is-47 {
  width: 47%;
}
.progress-bar.is-48 {
  width: 48%;
}
.progress-bar.is-49 {
  width: 49%;
}
.progress-bar.is-50 {
  width: 50%;
}
.progress-bar.is-51 {
  width: 51%;
}
.progress-bar.is-52 {
  width: 52%;
}
.progress-bar.is-53 {
  width: 53%;
}
.progress-bar.is-54 {
  width: 54%;
}
.progress-bar.is-55 {
  width: 55%;
}
.progress-bar.is-56 {
  width: 56%;
}
.progress-bar.is-57 {
  width: 57%;
}
.progress-bar.is-58 {
  width: 58%;
}
.progress-bar.is-59 {
  width: 59%;
}
.progress-bar.is-60 {
  width: 60%;
}
.progress-bar.is-61 {
  width: 61%;
}
.progress-bar.is-62 {
  width: 62%;
}
.progress-bar.is-63 {
  width: 63%;
}
.progress-bar.is-64 {
  width: 64%;
}
.progress-bar.is-65 {
  width: 65%;
}
.progress-bar.is-66 {
  width: 66%;
}
.progress-bar.is-67 {
  width: 67%;
}
.progress-bar.is-68 {
  width: 68%;
}
.progress-bar.is-69 {
  width: 69%;
}
.progress-bar.is-70 {
  width: 70%;
}
.progress-bar.is-71 {
  width: 71%;
}
.progress-bar.is-72 {
  width: 72%;
}
.progress-bar.is-73 {
  width: 73%;
}
.progress-bar.is-74 {
  width: 74%;
}
.progress-bar.is-75 {
  width: 75%;
}
.progress-bar.is-76 {
  width: 76%;
}
.progress-bar.is-77 {
  width: 77%;
}
.progress-bar.is-78 {
  width: 78%;
}
.progress-bar.is-79 {
  width: 79%;
}
.progress-bar.is-80 {
  width: 80%;
}
.progress-bar.is-81 {
  width: 81%;
}
.progress-bar.is-82 {
  width: 82%;
}
.progress-bar.is-83 {
  width: 83%;
}
.progress-bar.is-84 {
  width: 84%;
}
.progress-bar.is-85 {
  width: 85%;
}
.progress-bar.is-86 {
  width: 86%;
}
.progress-bar.is-87 {
  width: 87%;
}
.progress-bar.is-88 {
  width: 88%;
}
.progress-bar.is-89 {
  width: 89%;
}
.progress-bar.is-90 {
  width: 90%;
}
.progress-bar.is-91 {
  width: 91%;
}
.progress-bar.is-92 {
  width: 92%;
}
.progress-bar.is-93 {
  width: 93%;
}
.progress-bar.is-94 {
  width: 94%;
}
.progress-bar.is-95 {
  width: 95%;
}
.progress-bar.is-96 {
  width: 96%;
}
.progress-bar.is-97 {
  width: 97%;
}
.progress-bar.is-98 {
  width: 98%;
}
.progress-bar.is-99 {
  width: 99%;
}
.progress-bar.is-100 {
  width: 100%;
}

@keyframes vor-progress-stripes {
  from {
    background-position: 1rem 0;
  }
  to {
    background-position: 0 0;
  }
}
/* --------------------------------------------
   Buttons: Close / Icon (component)
-------------------------------------------- */
.btn-close {
  border: none;
  background: transparent;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  color: var(--text-muted);
  padding: 0.25rem 0.5rem;
  border-radius: 0.25rem;
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), color 150ms cubic-bezier(0.4, 0, 0.2, 1), transform 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-close:hover {
  background: rgba(0, 0, 0, 0.06);
  color: var(--text-main);
  transform: translateY(-1px);
}
.btn-close:active {
  transform: translateY(0);
}

[data-theme=dark] .btn-close:hover {
  background: rgba(255, 255, 255, 0.08);
}

/* --------------------------------------------
   App shell / Sidebar / Drawer / Modal
-------------------------------------------- */
.app-wrapper {
  display: flex;
  width: 100%;
  min-height: 100vh;
}

.sidebar {
  width: 280px;
  height: 100vh;
  position: sticky;
  top: 0;
  background-color: var(--bg-surface);
  border-right: 1px solid var(--border-color);
  display: flex;
  flex-direction: column;
  transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.sidebar.collapsed {
  width: 84px;
}

.drawer {
  position: fixed;
  top: 0;
  left: 0;
  width: 320px;
  max-width: 88vw;
  height: 100vh;
  z-index: 200;
  background-color: var(--bg-card);
  border-right: 1px solid var(--border-color);
  transform: translateX(-105%);
  transition: transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 11px 15px -7px rgba(0, 0, 0, 0.2), 0 24px 38px 3px rgba(0, 0, 0, 0.14), 0 9px 46px 8px rgba(0, 0, 0, 0.12);
}
.drawer.is-open {
  transform: translateX(0);
}

.main-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

/* Modal */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 500;
  padding: 1.5rem;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 250ms cubic-bezier(0.4, 0, 0.2, 1), visibility 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.modal-overlay.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.modal-content {
  background-color: var(--bg-card);
  border-radius: 1rem;
  width: 100%;
  max-width: 640px;
  box-shadow: 0 11px 15px -7px rgba(0, 0, 0, 0.2), 0 24px 38px 3px rgba(0, 0, 0, 0.14), 0 9px 46px 8px rgba(0, 0, 0, 0.12);
  overflow: hidden;
  border: 1px solid var(--border-color);
  transform: translateY(10px) scale(0.985);
  transition: transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.modal-overlay.is-active .modal-content {
  transform: translateY(0) scale(1);
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.5rem;
  border-bottom: 1px solid var(--border-color);
}

.modal-title {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--text-main);
}

.modal-body {
  padding: 1.5rem;
  color: var(--text-muted);
  max-height: 75vh;
  overflow-y: auto;
}
.modal-body p {
  margin: 0;
}

.modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--border-color);
  background: var(--bg-surface);
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
}

.vor-modal-sm {
  max-width: 480px;
}

.vor-modal-md {
  max-width: 640px;
}

.vor-modal-lg {
  max-width: 820px;
}

/* --------------------------------------------
   Accordion
-------------------------------------------- */
.accordion-item {
  border-bottom: 1px solid var(--border-color);
}
.accordion-item.is-active .accordion-body {
  display: block;
}
.accordion-item.is-active .accordion-icon {
  transform: rotate(180deg);
}
.accordion-item .accordion-header {
  padding: 1rem;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: none;
  border: none;
  width: 100%;
  color: var(--text-main);
}
.accordion-item .accordion-header:hover {
  background-color: var(--bg-surface);
}
.accordion-item .accordion-icon {
  transition: transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.accordion-item .accordion-body {
  padding: 0 1rem 1rem;
  display: none;
  color: var(--text-muted);
}

/* --------------------------------------------
   Switch
-------------------------------------------- */
.switch {
  --switch-width: 40px;
  --switch-height: 22px;
  position: relative;
  display: inline-block;
  width: var(--switch-width);
  height: var(--switch-height);
}
.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
.switch input:checked + .slider {
  background-color: var(--primary);
}
.switch input:checked + .slider::before {
  transform: translateX(18px);
}
.switch input:focus-visible + .slider {
  box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.35);
}
.switch .slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #dee2e6;
  transition: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 50rem;
}
.switch .slider::before {
  position: absolute;
  content: "";
  height: 16px;
  width: 16px;
  left: 3px;
  bottom: 3px;
  background-color: #ffffff;
  transition: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 50%;
}

/* --------------------------------------------
   Dividers / helpers
-------------------------------------------- */
.hr {
  border: none;
  border-top: 1px solid var(--border-color);
  margin: 1.5rem 0;
}

/* --------------------------------------------
   Drawer Modal (off-canvas modal)
-------------------------------------------- */
.drawer-modal {
  position: fixed;
  inset: 0;
  z-index: 500;
  display: flex;
  justify-content: flex-end;
  background-color: rgba(0, 0, 0, 0.55);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 250ms cubic-bezier(0.4, 0, 0.2, 1), visibility 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.drawer-modal.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* --------------------------------------------
   Drawer Modal (off-canvas modal)
-------------------------------------------- */
.drawer-modal {
  position: fixed;
  inset: 0;
  z-index: 500;
  display: flex;
  justify-content: flex-end; /* right default */
  background-color: rgba(0, 0, 0, 0.55);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 250ms cubic-bezier(0.4, 0, 0.2, 1), visibility 250ms cubic-bezier(0.4, 0, 0.2, 1);
}
.drawer-modal.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.drawer-modal.is-left {
  justify-content: flex-start;
}

.drawer-panel {
  width: 520px;
  max-width: 94vw;
  height: 100vh;
  background-color: var(--bg-card);
  box-shadow: 0 11px 15px -7px rgba(0, 0, 0, 0.2), 0 24px 38px 3px rgba(0, 0, 0, 0.14), 0 9px 46px 8px rgba(0, 0, 0, 0.12);
  display: flex;
  flex-direction: column;
  transition: transform 400ms cubic-bezier(0.4, 0, 0.2, 1);
  /* default: start off-screen right */
  transform: translateX(105%);
  border-left: 1px solid var(--border-color);
}
.drawer-modal.is-active .drawer-panel {
  transform: translateX(0);
}
.drawer-panel {
  /* left variant */
}
.drawer-modal.is-left .drawer-panel {
  transform: translateX(-105%);
  border-left: none;
  border-right: 1px solid var(--border-color);
}
.drawer-modal.is-left.is-active .drawer-panel {
  transform: translateX(0);
}

.drawer-panel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.5rem;
  border-bottom: 1px solid var(--border-color);
}

.drawer-panel-body {
  padding: 1.5rem;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  flex: 1;
}

.drawer-panel-footer {
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--border-color);
}

/* Dark mode tweaks (optional, usually already handled by tokens) */
[data-theme=dark] .drawer-modal {
  background-color: rgba(0, 0, 0, 0.65);
}/*# sourceMappingURL=main.css.map */