@charset "UTF-8";
/* ==========================================================================
   EmpowHERto — Main SCSS (order-driven, no @layer)
   - Bootstrap functions first
   - Our token overrides BEFORE Bootstrap variables/maps/mixins
   - Then Bootstrap components
   - Then our modern SCSS
   - Legacy last so it wins until we migrate it away
   ========================================================================== */
/* 1) Bootstrap (SCSS core) */
/* 2) Tokens (override Bootstrap vars BEFORE Bootstrap variables) */
/* html/assets/scss/tokens/_variables.scss */
/* You can also tweak Bootstrap maps if needed, e.g.
$theme-colors: (
  "primary": $primary,
  "secondary": $secondary,
  "success": #28a745,
  "info": #17a2b8,
  "warning": #ffc107,
  "danger": #dc3545,
  "light": #f8f9fa,
  "dark": #212529
);
*/
/* 3) Bootstrap variables + the rest */
:root,
[data-bs-theme=light] {
  --bs-blue: #0d6efd;
  --bs-indigo: #6610f2;
  --bs-purple: #6f42c1;
  --bs-pink: #d63384;
  --bs-red: #dc3545;
  --bs-orange: #fd7e14;
  --bs-yellow: #ffc107;
  --bs-green: #198754;
  --bs-teal: #20c997;
  --bs-cyan: #0dcaf0;
  --bs-black: #000;
  --bs-white: #fff;
  --bs-gray: #6c757d;
  --bs-gray-dark: #343a40;
  --bs-gray-100: #f8f9fa;
  --bs-gray-200: #e9ecef;
  --bs-gray-300: #dee2e6;
  --bs-gray-400: #ced4da;
  --bs-gray-500: #adb5bd;
  --bs-gray-600: #6c757d;
  --bs-gray-700: #495057;
  --bs-gray-800: #343a40;
  --bs-gray-900: #212529;
  --bs-primary: #6a4df5;
  --bs-secondary: #1363df;
  --bs-success: #198754;
  --bs-info: #0dcaf0;
  --bs-warning: #ffc107;
  --bs-danger: #dc3545;
  --bs-light: #f8f9fa;
  --bs-dark: #212529;
  --bs-primary-rgb: 106, 77, 245;
  --bs-secondary-rgb: 19, 99, 223;
  --bs-success-rgb: 25, 135, 84;
  --bs-info-rgb: 13, 202, 240;
  --bs-warning-rgb: 255, 193, 7;
  --bs-danger-rgb: 220, 53, 69;
  --bs-light-rgb: 248, 249, 250;
  --bs-dark-rgb: 33, 37, 41;
  --bs-primary-text-emphasis: rgb(42.4, 30.8, 98);
  --bs-secondary-text-emphasis: rgb(7.6, 39.6, 89.2);
  --bs-success-text-emphasis: rgb(10, 54, 33.6);
  --bs-info-text-emphasis: rgb(5.2, 80.8, 96);
  --bs-warning-text-emphasis: rgb(102, 77.2, 2.8);
  --bs-danger-text-emphasis: rgb(88, 21.2, 27.6);
  --bs-light-text-emphasis: #495057;
  --bs-dark-text-emphasis: #495057;
  --bs-primary-bg-subtle: rgb(225.2, 219.4, 253);
  --bs-secondary-bg-subtle: rgb(207.8, 223.8, 248.6);
  --bs-success-bg-subtle: rgb(209, 231, 220.8);
  --bs-info-bg-subtle: rgb(206.6, 244.4, 252);
  --bs-warning-bg-subtle: rgb(255, 242.6, 205.4);
  --bs-danger-bg-subtle: rgb(248, 214.6, 217.8);
  --bs-light-bg-subtle: rgb(251.5, 252, 252.5);
  --bs-dark-bg-subtle: #ced4da;
  --bs-primary-border-subtle: rgb(195.4, 183.8, 251);
  --bs-secondary-border-subtle: rgb(160.6, 192.6, 242.2);
  --bs-success-border-subtle: rgb(163, 207, 186.6);
  --bs-info-border-subtle: rgb(158.2, 233.8, 249);
  --bs-warning-border-subtle: rgb(255, 230.2, 155.8);
  --bs-danger-border-subtle: rgb(241, 174.2, 180.6);
  --bs-light-border-subtle: #e9ecef;
  --bs-dark-border-subtle: #adb5bd;
  --bs-white-rgb: 255, 255, 255;
  --bs-black-rgb: 0, 0, 0;
  --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --bs-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --bs-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
  --bs-body-font-family: var(--bs-font-sans-serif);
  --bs-body-font-size: 1rem;
  --bs-body-font-weight: 400;
  --bs-body-line-height: 1.5;
  --bs-body-color: #212529;
  --bs-body-color-rgb: 33, 37, 41;
  --bs-body-bg: #fff;
  --bs-body-bg-rgb: 255, 255, 255;
  --bs-emphasis-color: #000;
  --bs-emphasis-color-rgb: 0, 0, 0;
  --bs-secondary-color: rgba(33, 37, 41, 0.75);
  --bs-secondary-color-rgb: 33, 37, 41;
  --bs-secondary-bg: #e9ecef;
  --bs-secondary-bg-rgb: 233, 236, 239;
  --bs-tertiary-color: rgba(33, 37, 41, 0.5);
  --bs-tertiary-color-rgb: 33, 37, 41;
  --bs-tertiary-bg: #f8f9fa;
  --bs-tertiary-bg-rgb: 248, 249, 250;
  --bs-heading-color: inherit;
  --bs-link-color: #6a4df5;
  --bs-link-color-rgb: 106, 77, 245;
  --bs-link-decoration: underline;
  --bs-link-hover-color: rgb(84.8, 61.6, 196);
  --bs-link-hover-color-rgb: 85, 62, 196;
  --bs-code-color: #d63384;
  --bs-highlight-color: #212529;
  --bs-highlight-bg: rgb(255, 242.6, 205.4);
  --bs-border-width: 1px;
  --bs-border-style: solid;
  --bs-border-color: #dee2e6;
  --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
  --bs-border-radius: 0.375rem;
  --bs-border-radius-sm: 0.25rem;
  --bs-border-radius-lg: 0.5rem;
  --bs-border-radius-xl: 1rem;
  --bs-border-radius-xxl: 2rem;
  --bs-border-radius-2xl: var(--bs-border-radius-xxl);
  --bs-border-radius-pill: 50rem;
  --bs-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --bs-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --bs-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
  --bs-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, 0.075);
  --bs-focus-ring-width: 0.25rem;
  --bs-focus-ring-opacity: 0.25;
  --bs-focus-ring-color: rgba(106, 77, 245, 0.25);
  --bs-form-valid-color: #198754;
  --bs-form-valid-border-color: #198754;
  --bs-form-invalid-color: #dc3545;
  --bs-form-invalid-border-color: #dc3545;
}

[data-bs-theme=dark] {
  color-scheme: dark;
  --bs-body-color: #dee2e6;
  --bs-body-color-rgb: 222, 226, 230;
  --bs-body-bg: #212529;
  --bs-body-bg-rgb: 33, 37, 41;
  --bs-emphasis-color: #fff;
  --bs-emphasis-color-rgb: 255, 255, 255;
  --bs-secondary-color: rgba(222, 226, 230, 0.75);
  --bs-secondary-color-rgb: 222, 226, 230;
  --bs-secondary-bg: #343a40;
  --bs-secondary-bg-rgb: 52, 58, 64;
  --bs-tertiary-color: rgba(222, 226, 230, 0.5);
  --bs-tertiary-color-rgb: 222, 226, 230;
  --bs-tertiary-bg: rgb(42.5, 47.5, 52.5);
  --bs-tertiary-bg-rgb: 43, 48, 53;
  --bs-primary-text-emphasis: rgb(165.6, 148.2, 249);
  --bs-secondary-text-emphasis: rgb(113.4, 161.4, 235.8);
  --bs-success-text-emphasis: rgb(117, 183, 152.4);
  --bs-info-text-emphasis: rgb(109.8, 223.2, 246);
  --bs-warning-text-emphasis: rgb(255, 217.8, 106.2);
  --bs-danger-text-emphasis: rgb(234, 133.8, 143.4);
  --bs-light-text-emphasis: #f8f9fa;
  --bs-dark-text-emphasis: #dee2e6;
  --bs-primary-bg-subtle: rgb(21.2, 15.4, 49);
  --bs-secondary-bg-subtle: rgb(3.8, 19.8, 44.6);
  --bs-success-bg-subtle: rgb(5, 27, 16.8);
  --bs-info-bg-subtle: rgb(2.6, 40.4, 48);
  --bs-warning-bg-subtle: rgb(51, 38.6, 1.4);
  --bs-danger-bg-subtle: rgb(44, 10.6, 13.8);
  --bs-light-bg-subtle: #343a40;
  --bs-dark-bg-subtle: #1a1d20;
  --bs-primary-border-subtle: rgb(63.6, 46.2, 147);
  --bs-secondary-border-subtle: rgb(11.4, 59.4, 133.8);
  --bs-success-border-subtle: rgb(15, 81, 50.4);
  --bs-info-border-subtle: rgb(7.8, 121.2, 144);
  --bs-warning-border-subtle: rgb(153, 115.8, 4.2);
  --bs-danger-border-subtle: rgb(132, 31.8, 41.4);
  --bs-light-border-subtle: #495057;
  --bs-dark-border-subtle: #343a40;
  --bs-heading-color: inherit;
  --bs-link-color: rgb(165.6, 148.2, 249);
  --bs-link-hover-color: rgb(183.48, 169.56, 250.2);
  --bs-link-color-rgb: 166, 148, 249;
  --bs-link-hover-color-rgb: 183, 170, 250;
  --bs-code-color: rgb(230.4, 132.6, 181.2);
  --bs-highlight-color: #dee2e6;
  --bs-highlight-bg: rgb(102, 77.2, 2.8);
  --bs-border-color: #495057;
  --bs-border-color-translucent: rgba(255, 255, 255, 0.15);
  --bs-form-valid-color: rgb(117, 183, 152.4);
  --bs-form-valid-border-color: rgb(117, 183, 152.4);
  --bs-form-invalid-color: rgb(234, 133.8, 143.4);
  --bs-form-invalid-border-color: rgb(234, 133.8, 143.4);
}

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

@media (prefers-reduced-motion: no-preference) {
  :root {
    scroll-behavior: smooth;
  }
}

body {
  margin: 0;
  font-family: var(--bs-body-font-family);
  font-size: var(--bs-body-font-size);
  font-weight: var(--bs-body-font-weight);
  line-height: var(--bs-body-line-height);
  color: var(--bs-body-color);
  text-align: var(--bs-body-text-align);
  background-color: var(--bs-body-bg);
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

hr {
  margin: 1rem 0;
  color: inherit;
  border: 0;
  border-top: var(--bs-border-width) solid;
  opacity: 0.25;
}

h6, .h6, h5, .h5, h4, .h4, h3, .h3, h2, .h2, h1, .h1 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-weight: 500;
  line-height: 1.2;
  color: var(--bs-heading-color);
}

h1, .h1 {
  font-size: calc(1.375rem + 1.5vw);
}
@media (min-width: 1200px) {
  h1, .h1 {
    font-size: 2.5rem;
  }
}

h2, .h2 {
  font-size: calc(1.325rem + 0.9vw);
}
@media (min-width: 1200px) {
  h2, .h2 {
    font-size: 2rem;
  }
}

h3, .h3 {
  font-size: calc(1.3rem + 0.6vw);
}
@media (min-width: 1200px) {
  h3, .h3 {
    font-size: 1.75rem;
  }
}

h4, .h4 {
  font-size: calc(1.275rem + 0.3vw);
}
@media (min-width: 1200px) {
  h4, .h4 {
    font-size: 1.5rem;
  }
}

h5, .h5 {
  font-size: 1.25rem;
}

h6, .h6 {
  font-size: 1rem;
}

p {
  margin-top: 0;
  margin-bottom: 1rem;
}

abbr[title] {
  text-decoration: underline dotted;
  cursor: help;
  text-decoration-skip-ink: none;
}

address {
  margin-bottom: 1rem;
  font-style: normal;
  line-height: inherit;
}

ol,
ul {
  padding-left: 2rem;
}

ol,
ul,
dl {
  margin-top: 0;
  margin-bottom: 1rem;
}

ol ol,
ul ul,
ol ul,
ul ol {
  margin-bottom: 0;
}

dt {
  font-weight: 700;
}

dd {
  margin-bottom: 0.5rem;
  margin-left: 0;
}

blockquote {
  margin: 0 0 1rem;
}

b,
strong {
  font-weight: bolder;
}

small, .small {
  font-size: 0.875em;
}

mark, .mark {
  padding: 0.1875em;
  color: var(--bs-highlight-color);
  background-color: var(--bs-highlight-bg);
}

sub,
sup {
  position: relative;
  font-size: 0.75em;
  line-height: 0;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

a {
  color: rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 1));
  text-decoration: underline;
}
a:hover {
  --bs-link-color-rgb: var(--bs-link-hover-color-rgb);
}

a:not([href]):not([class]), a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none;
}

pre,
code,
kbd,
samp {
  font-family: var(--bs-font-monospace);
  font-size: 1em;
}

pre {
  display: block;
  margin-top: 0;
  margin-bottom: 1rem;
  overflow: auto;
  font-size: 0.875em;
}
pre code {
  font-size: inherit;
  color: inherit;
  word-break: normal;
}

code {
  font-size: 0.875em;
  color: var(--bs-code-color);
  word-wrap: break-word;
}
a > code {
  color: inherit;
}

kbd {
  padding: 0.1875rem 0.375rem;
  font-size: 0.875em;
  color: var(--bs-body-bg);
  background-color: var(--bs-body-color);
  border-radius: 0.25rem;
}
kbd kbd {
  padding: 0;
  font-size: 1em;
}

figure {
  margin: 0 0 1rem;
}

img,
svg {
  vertical-align: middle;
}

table {
  caption-side: bottom;
  border-collapse: collapse;
}

caption {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  color: var(--bs-secondary-color);
  text-align: left;
}

th {
  text-align: inherit;
  text-align: -webkit-match-parent;
}

thead,
tbody,
tfoot,
tr,
td,
th {
  border-color: inherit;
  border-style: solid;
  border-width: 0;
}

label {
  display: inline-block;
}

button {
  border-radius: 0;
}

button:focus:not(:focus-visible) {
  outline: 0;
}

input,
button,
select,
optgroup,
textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

button,
select {
  text-transform: none;
}

[role=button] {
  cursor: pointer;
}

select {
  word-wrap: normal;
}
select:disabled {
  opacity: 1;
}

[list]:not([type=date]):not([type=datetime-local]):not([type=month]):not([type=week]):not([type=time])::-webkit-calendar-picker-indicator {
  display: none !important;
}

button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}
button:not(:disabled),
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled) {
  cursor: pointer;
}

::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

textarea {
  resize: vertical;
}

fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
}

legend {
  float: left;
  width: 100%;
  padding: 0;
  margin-bottom: 0.5rem;
  line-height: inherit;
  font-size: calc(1.275rem + 0.3vw);
}
@media (min-width: 1200px) {
  legend {
    font-size: 1.5rem;
  }
}
legend + * {
  clear: left;
}

::-webkit-datetime-edit-fields-wrapper,
::-webkit-datetime-edit-text,
::-webkit-datetime-edit-minute,
::-webkit-datetime-edit-hour-field,
::-webkit-datetime-edit-day-field,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-year-field {
  padding: 0;
}

::-webkit-inner-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}
[type=search]::-webkit-search-cancel-button {
  cursor: pointer;
  filter: grayscale(1);
}

/* rtl:raw:
[type="tel"],
[type="url"],
[type="email"],
[type="number"] {
  direction: ltr;
}
*/
::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-color-swatch-wrapper {
  padding: 0;
}

::file-selector-button {
  font: inherit;
  -webkit-appearance: button;
}

output {
  display: inline-block;
}

iframe {
  border: 0;
}

summary {
  display: list-item;
  cursor: pointer;
}

progress {
  vertical-align: baseline;
}

[hidden] {
  display: none !important;
}

.lead {
  font-size: 1.25rem;
  font-weight: 300;
}

.display-1 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.625rem + 4.5vw);
}
@media (min-width: 1200px) {
  .display-1 {
    font-size: 5rem;
  }
}

.display-2 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.575rem + 3.9vw);
}
@media (min-width: 1200px) {
  .display-2 {
    font-size: 4.5rem;
  }
}

.display-3 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.525rem + 3.3vw);
}
@media (min-width: 1200px) {
  .display-3 {
    font-size: 4rem;
  }
}

.display-4 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.475rem + 2.7vw);
}
@media (min-width: 1200px) {
  .display-4 {
    font-size: 3.5rem;
  }
}

.display-5 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.425rem + 2.1vw);
}
@media (min-width: 1200px) {
  .display-5 {
    font-size: 3rem;
  }
}

.display-6 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.375rem + 1.5vw);
}
@media (min-width: 1200px) {
  .display-6 {
    font-size: 2.5rem;
  }
}

.list-unstyled {
  padding-left: 0;
  list-style: none;
}

.list-inline {
  padding-left: 0;
  list-style: none;
}

.list-inline-item {
  display: inline-block;
}
.list-inline-item:not(:last-child) {
  margin-right: 0.5rem;
}

.initialism {
  font-size: 0.875em;
  text-transform: uppercase;
}

.blockquote {
  margin-bottom: 1rem;
  font-size: 1.25rem;
}
.blockquote > :last-child {
  margin-bottom: 0;
}

.blockquote-footer {
  margin-top: -1rem;
  margin-bottom: 1rem;
  font-size: 0.875em;
  color: #6c757d;
}
.blockquote-footer::before {
  content: "— ";
}

.img-fluid {
  max-width: 100%;
  height: auto;
}

.img-thumbnail {
  padding: 0.25rem;
  background-color: var(--bs-body-bg);
  border: var(--bs-border-width) solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  max-width: 100%;
  height: auto;
}

.figure {
  display: inline-block;
}

.figure-img {
  margin-bottom: 0.5rem;
  line-height: 1;
}

.figure-caption {
  font-size: 0.875em;
  color: var(--bs-secondary-color);
}

.container,
.container-fluid,
.container-xxl,
.container-xl,
.container-lg,
.container-md,
.container-sm {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 576px) {
  .container-sm, .container {
    max-width: 540px;
  }
}
@media (min-width: 768px) {
  .container-md, .container-sm, .container {
    max-width: 720px;
  }
}
@media (min-width: 992px) {
  .container-lg, .container-md, .container-sm, .container {
    max-width: 960px;
  }
}
@media (min-width: 1200px) {
  .container-xl, .container-lg, .container-md, .container-sm, .container {
    max-width: 1140px;
  }
}
@media (min-width: 1400px) {
  .container-xxl, .container-xl, .container-lg, .container-md, .container-sm, .container {
    max-width: 1320px;
  }
}
:root {
  --bs-breakpoint-xs: 0;
  --bs-breakpoint-sm: 576px;
  --bs-breakpoint-md: 768px;
  --bs-breakpoint-lg: 992px;
  --bs-breakpoint-xl: 1200px;
  --bs-breakpoint-xxl: 1400px;
}

.row {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--bs-gutter-y));
  margin-right: calc(-0.5 * var(--bs-gutter-x));
  margin-left: calc(-0.5 * var(--bs-gutter-x));
}
.row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}

.col {
  flex: 1 0 0;
}

.row-cols-auto > * {
  flex: 0 0 auto;
  width: auto;
}

.row-cols-1 > * {
  flex: 0 0 auto;
  width: 100%;
}

.row-cols-2 > * {
  flex: 0 0 auto;
  width: 50%;
}

.row-cols-3 > * {
  flex: 0 0 auto;
  width: 33.33333333%;
}

.row-cols-4 > * {
  flex: 0 0 auto;
  width: 25%;
}

.row-cols-5 > * {
  flex: 0 0 auto;
  width: 20%;
}

.row-cols-6 > * {
  flex: 0 0 auto;
  width: 16.66666667%;
}

.col-auto {
  flex: 0 0 auto;
  width: auto;
}

.col-1 {
  flex: 0 0 auto;
  width: 8.33333333%;
}

.col-2 {
  flex: 0 0 auto;
  width: 16.66666667%;
}

.col-3 {
  flex: 0 0 auto;
  width: 25%;
}

.col-4 {
  flex: 0 0 auto;
  width: 33.33333333%;
}

.col-5 {
  flex: 0 0 auto;
  width: 41.66666667%;
}

.col-6 {
  flex: 0 0 auto;
  width: 50%;
}

.col-7 {
  flex: 0 0 auto;
  width: 58.33333333%;
}

.col-8 {
  flex: 0 0 auto;
  width: 66.66666667%;
}

.col-9 {
  flex: 0 0 auto;
  width: 75%;
}

.col-10 {
  flex: 0 0 auto;
  width: 83.33333333%;
}

.col-11 {
  flex: 0 0 auto;
  width: 91.66666667%;
}

.col-12 {
  flex: 0 0 auto;
  width: 100%;
}

.offset-1 {
  margin-left: 8.33333333%;
}

.offset-2 {
  margin-left: 16.66666667%;
}

.offset-3 {
  margin-left: 25%;
}

.offset-4 {
  margin-left: 33.33333333%;
}

.offset-5 {
  margin-left: 41.66666667%;
}

.offset-6 {
  margin-left: 50%;
}

.offset-7 {
  margin-left: 58.33333333%;
}

.offset-8 {
  margin-left: 66.66666667%;
}

.offset-9 {
  margin-left: 75%;
}

.offset-10 {
  margin-left: 83.33333333%;
}

.offset-11 {
  margin-left: 91.66666667%;
}

.g-0,
.gx-0 {
  --bs-gutter-x: 0;
}

.g-0,
.gy-0 {
  --bs-gutter-y: 0;
}

.g-1,
.gx-1 {
  --bs-gutter-x: 0.25rem;
}

.g-1,
.gy-1 {
  --bs-gutter-y: 0.25rem;
}

.g-2,
.gx-2 {
  --bs-gutter-x: 0.5rem;
}

.g-2,
.gy-2 {
  --bs-gutter-y: 0.5rem;
}

.g-3,
.gx-3 {
  --bs-gutter-x: 1rem;
}

.g-3,
.gy-3 {
  --bs-gutter-y: 1rem;
}

.g-4,
.gx-4 {
  --bs-gutter-x: 1.5rem;
}

.g-4,
.gy-4 {
  --bs-gutter-y: 1.5rem;
}

.g-5,
.gx-5 {
  --bs-gutter-x: 3rem;
}

.g-5,
.gy-5 {
  --bs-gutter-y: 3rem;
}

@media (min-width: 576px) {
  .col-sm {
    flex: 1 0 0;
  }
  .row-cols-sm-auto > * {
    flex: 0 0 auto;
    width: auto;
  }
  .row-cols-sm-1 > * {
    flex: 0 0 auto;
    width: 100%;
  }
  .row-cols-sm-2 > * {
    flex: 0 0 auto;
    width: 50%;
  }
  .row-cols-sm-3 > * {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .row-cols-sm-4 > * {
    flex: 0 0 auto;
    width: 25%;
  }
  .row-cols-sm-5 > * {
    flex: 0 0 auto;
    width: 20%;
  }
  .row-cols-sm-6 > * {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-sm-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-sm-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-sm-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-sm-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-sm-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-sm-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-sm-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-sm-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-sm-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-sm-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-sm-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-sm-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-sm-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-sm-0 {
    margin-left: 0;
  }
  .offset-sm-1 {
    margin-left: 8.33333333%;
  }
  .offset-sm-2 {
    margin-left: 16.66666667%;
  }
  .offset-sm-3 {
    margin-left: 25%;
  }
  .offset-sm-4 {
    margin-left: 33.33333333%;
  }
  .offset-sm-5 {
    margin-left: 41.66666667%;
  }
  .offset-sm-6 {
    margin-left: 50%;
  }
  .offset-sm-7 {
    margin-left: 58.33333333%;
  }
  .offset-sm-8 {
    margin-left: 66.66666667%;
  }
  .offset-sm-9 {
    margin-left: 75%;
  }
  .offset-sm-10 {
    margin-left: 83.33333333%;
  }
  .offset-sm-11 {
    margin-left: 91.66666667%;
  }
  .g-sm-0,
  .gx-sm-0 {
    --bs-gutter-x: 0;
  }
  .g-sm-0,
  .gy-sm-0 {
    --bs-gutter-y: 0;
  }
  .g-sm-1,
  .gx-sm-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-sm-1,
  .gy-sm-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-sm-2,
  .gx-sm-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-sm-2,
  .gy-sm-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-sm-3,
  .gx-sm-3 {
    --bs-gutter-x: 1rem;
  }
  .g-sm-3,
  .gy-sm-3 {
    --bs-gutter-y: 1rem;
  }
  .g-sm-4,
  .gx-sm-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-sm-4,
  .gy-sm-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-sm-5,
  .gx-sm-5 {
    --bs-gutter-x: 3rem;
  }
  .g-sm-5,
  .gy-sm-5 {
    --bs-gutter-y: 3rem;
  }
}
@media (min-width: 768px) {
  .col-md {
    flex: 1 0 0;
  }
  .row-cols-md-auto > * {
    flex: 0 0 auto;
    width: auto;
  }
  .row-cols-md-1 > * {
    flex: 0 0 auto;
    width: 100%;
  }
  .row-cols-md-2 > * {
    flex: 0 0 auto;
    width: 50%;
  }
  .row-cols-md-3 > * {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .row-cols-md-4 > * {
    flex: 0 0 auto;
    width: 25%;
  }
  .row-cols-md-5 > * {
    flex: 0 0 auto;
    width: 20%;
  }
  .row-cols-md-6 > * {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-md-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-md-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-md-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-md-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-md-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-md-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-md-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-md-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-md-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-md-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-md-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-md-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-md-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-md-0 {
    margin-left: 0;
  }
  .offset-md-1 {
    margin-left: 8.33333333%;
  }
  .offset-md-2 {
    margin-left: 16.66666667%;
  }
  .offset-md-3 {
    margin-left: 25%;
  }
  .offset-md-4 {
    margin-left: 33.33333333%;
  }
  .offset-md-5 {
    margin-left: 41.66666667%;
  }
  .offset-md-6 {
    margin-left: 50%;
  }
  .offset-md-7 {
    margin-left: 58.33333333%;
  }
  .offset-md-8 {
    margin-left: 66.66666667%;
  }
  .offset-md-9 {
    margin-left: 75%;
  }
  .offset-md-10 {
    margin-left: 83.33333333%;
  }
  .offset-md-11 {
    margin-left: 91.66666667%;
  }
  .g-md-0,
  .gx-md-0 {
    --bs-gutter-x: 0;
  }
  .g-md-0,
  .gy-md-0 {
    --bs-gutter-y: 0;
  }
  .g-md-1,
  .gx-md-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-md-1,
  .gy-md-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-md-2,
  .gx-md-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-md-2,
  .gy-md-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-md-3,
  .gx-md-3 {
    --bs-gutter-x: 1rem;
  }
  .g-md-3,
  .gy-md-3 {
    --bs-gutter-y: 1rem;
  }
  .g-md-4,
  .gx-md-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-md-4,
  .gy-md-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-md-5,
  .gx-md-5 {
    --bs-gutter-x: 3rem;
  }
  .g-md-5,
  .gy-md-5 {
    --bs-gutter-y: 3rem;
  }
}
@media (min-width: 992px) {
  .col-lg {
    flex: 1 0 0;
  }
  .row-cols-lg-auto > * {
    flex: 0 0 auto;
    width: auto;
  }
  .row-cols-lg-1 > * {
    flex: 0 0 auto;
    width: 100%;
  }
  .row-cols-lg-2 > * {
    flex: 0 0 auto;
    width: 50%;
  }
  .row-cols-lg-3 > * {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .row-cols-lg-4 > * {
    flex: 0 0 auto;
    width: 25%;
  }
  .row-cols-lg-5 > * {
    flex: 0 0 auto;
    width: 20%;
  }
  .row-cols-lg-6 > * {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-lg-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-lg-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-lg-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-lg-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-lg-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-lg-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-lg-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-lg-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-lg-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-lg-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-lg-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-lg-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-lg-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-lg-0 {
    margin-left: 0;
  }
  .offset-lg-1 {
    margin-left: 8.33333333%;
  }
  .offset-lg-2 {
    margin-left: 16.66666667%;
  }
  .offset-lg-3 {
    margin-left: 25%;
  }
  .offset-lg-4 {
    margin-left: 33.33333333%;
  }
  .offset-lg-5 {
    margin-left: 41.66666667%;
  }
  .offset-lg-6 {
    margin-left: 50%;
  }
  .offset-lg-7 {
    margin-left: 58.33333333%;
  }
  .offset-lg-8 {
    margin-left: 66.66666667%;
  }
  .offset-lg-9 {
    margin-left: 75%;
  }
  .offset-lg-10 {
    margin-left: 83.33333333%;
  }
  .offset-lg-11 {
    margin-left: 91.66666667%;
  }
  .g-lg-0,
  .gx-lg-0 {
    --bs-gutter-x: 0;
  }
  .g-lg-0,
  .gy-lg-0 {
    --bs-gutter-y: 0;
  }
  .g-lg-1,
  .gx-lg-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-lg-1,
  .gy-lg-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-lg-2,
  .gx-lg-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-lg-2,
  .gy-lg-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-lg-3,
  .gx-lg-3 {
    --bs-gutter-x: 1rem;
  }
  .g-lg-3,
  .gy-lg-3 {
    --bs-gutter-y: 1rem;
  }
  .g-lg-4,
  .gx-lg-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-lg-4,
  .gy-lg-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-lg-5,
  .gx-lg-5 {
    --bs-gutter-x: 3rem;
  }
  .g-lg-5,
  .gy-lg-5 {
    --bs-gutter-y: 3rem;
  }
}
@media (min-width: 1200px) {
  .col-xl {
    flex: 1 0 0;
  }
  .row-cols-xl-auto > * {
    flex: 0 0 auto;
    width: auto;
  }
  .row-cols-xl-1 > * {
    flex: 0 0 auto;
    width: 100%;
  }
  .row-cols-xl-2 > * {
    flex: 0 0 auto;
    width: 50%;
  }
  .row-cols-xl-3 > * {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .row-cols-xl-4 > * {
    flex: 0 0 auto;
    width: 25%;
  }
  .row-cols-xl-5 > * {
    flex: 0 0 auto;
    width: 20%;
  }
  .row-cols-xl-6 > * {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-xl-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-xl-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-xl-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-xl-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-xl-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-xl-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-xl-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-xl-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-xl-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-xl-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-xl-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-xl-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-xl-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-xl-0 {
    margin-left: 0;
  }
  .offset-xl-1 {
    margin-left: 8.33333333%;
  }
  .offset-xl-2 {
    margin-left: 16.66666667%;
  }
  .offset-xl-3 {
    margin-left: 25%;
  }
  .offset-xl-4 {
    margin-left: 33.33333333%;
  }
  .offset-xl-5 {
    margin-left: 41.66666667%;
  }
  .offset-xl-6 {
    margin-left: 50%;
  }
  .offset-xl-7 {
    margin-left: 58.33333333%;
  }
  .offset-xl-8 {
    margin-left: 66.66666667%;
  }
  .offset-xl-9 {
    margin-left: 75%;
  }
  .offset-xl-10 {
    margin-left: 83.33333333%;
  }
  .offset-xl-11 {
    margin-left: 91.66666667%;
  }
  .g-xl-0,
  .gx-xl-0 {
    --bs-gutter-x: 0;
  }
  .g-xl-0,
  .gy-xl-0 {
    --bs-gutter-y: 0;
  }
  .g-xl-1,
  .gx-xl-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-xl-1,
  .gy-xl-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-xl-2,
  .gx-xl-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-xl-2,
  .gy-xl-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-xl-3,
  .gx-xl-3 {
    --bs-gutter-x: 1rem;
  }
  .g-xl-3,
  .gy-xl-3 {
    --bs-gutter-y: 1rem;
  }
  .g-xl-4,
  .gx-xl-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-xl-4,
  .gy-xl-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-xl-5,
  .gx-xl-5 {
    --bs-gutter-x: 3rem;
  }
  .g-xl-5,
  .gy-xl-5 {
    --bs-gutter-y: 3rem;
  }
}
@media (min-width: 1400px) {
  .col-xxl {
    flex: 1 0 0;
  }
  .row-cols-xxl-auto > * {
    flex: 0 0 auto;
    width: auto;
  }
  .row-cols-xxl-1 > * {
    flex: 0 0 auto;
    width: 100%;
  }
  .row-cols-xxl-2 > * {
    flex: 0 0 auto;
    width: 50%;
  }
  .row-cols-xxl-3 > * {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .row-cols-xxl-4 > * {
    flex: 0 0 auto;
    width: 25%;
  }
  .row-cols-xxl-5 > * {
    flex: 0 0 auto;
    width: 20%;
  }
  .row-cols-xxl-6 > * {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-xxl-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-xxl-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-xxl-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-xxl-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-xxl-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-xxl-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-xxl-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-xxl-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-xxl-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-xxl-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-xxl-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-xxl-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-xxl-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-xxl-0 {
    margin-left: 0;
  }
  .offset-xxl-1 {
    margin-left: 8.33333333%;
  }
  .offset-xxl-2 {
    margin-left: 16.66666667%;
  }
  .offset-xxl-3 {
    margin-left: 25%;
  }
  .offset-xxl-4 {
    margin-left: 33.33333333%;
  }
  .offset-xxl-5 {
    margin-left: 41.66666667%;
  }
  .offset-xxl-6 {
    margin-left: 50%;
  }
  .offset-xxl-7 {
    margin-left: 58.33333333%;
  }
  .offset-xxl-8 {
    margin-left: 66.66666667%;
  }
  .offset-xxl-9 {
    margin-left: 75%;
  }
  .offset-xxl-10 {
    margin-left: 83.33333333%;
  }
  .offset-xxl-11 {
    margin-left: 91.66666667%;
  }
  .g-xxl-0,
  .gx-xxl-0 {
    --bs-gutter-x: 0;
  }
  .g-xxl-0,
  .gy-xxl-0 {
    --bs-gutter-y: 0;
  }
  .g-xxl-1,
  .gx-xxl-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-xxl-1,
  .gy-xxl-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-xxl-2,
  .gx-xxl-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-xxl-2,
  .gy-xxl-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-xxl-3,
  .gx-xxl-3 {
    --bs-gutter-x: 1rem;
  }
  .g-xxl-3,
  .gy-xxl-3 {
    --bs-gutter-y: 1rem;
  }
  .g-xxl-4,
  .gx-xxl-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-xxl-4,
  .gy-xxl-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-xxl-5,
  .gx-xxl-5 {
    --bs-gutter-x: 3rem;
  }
  .g-xxl-5,
  .gy-xxl-5 {
    --bs-gutter-y: 3rem;
  }
}
.clearfix::after {
  display: block;
  clear: both;
  content: "";
}

.text-bg-primary {
  color: #fff !important;
  background-color: RGBA(var(--bs-primary-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-secondary {
  color: #fff !important;
  background-color: RGBA(var(--bs-secondary-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-success {
  color: #fff !important;
  background-color: RGBA(var(--bs-success-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-info {
  color: #000 !important;
  background-color: RGBA(var(--bs-info-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-warning {
  color: #000 !important;
  background-color: RGBA(var(--bs-warning-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-danger {
  color: #fff !important;
  background-color: RGBA(var(--bs-danger-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-light {
  color: #000 !important;
  background-color: RGBA(var(--bs-light-rgb), var(--bs-bg-opacity, 1)) !important;
}

.text-bg-dark {
  color: #fff !important;
  background-color: RGBA(var(--bs-dark-rgb), var(--bs-bg-opacity, 1)) !important;
}

.link-primary {
  color: RGBA(var(--bs-primary-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-primary-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-primary:hover, .link-primary:focus {
  color: RGBA(85, 62, 196, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(85, 62, 196, var(--bs-link-underline-opacity, 1)) !important;
}

.link-secondary {
  color: RGBA(var(--bs-secondary-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-secondary-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-secondary:hover, .link-secondary:focus {
  color: RGBA(15, 79, 178, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(15, 79, 178, var(--bs-link-underline-opacity, 1)) !important;
}

.link-success {
  color: RGBA(var(--bs-success-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-success-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-success:hover, .link-success:focus {
  color: RGBA(20, 108, 67, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(20, 108, 67, var(--bs-link-underline-opacity, 1)) !important;
}

.link-info {
  color: RGBA(var(--bs-info-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-info-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-info:hover, .link-info:focus {
  color: RGBA(61, 213, 243, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(61, 213, 243, var(--bs-link-underline-opacity, 1)) !important;
}

.link-warning {
  color: RGBA(var(--bs-warning-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-warning-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-warning:hover, .link-warning:focus {
  color: RGBA(255, 205, 57, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(255, 205, 57, var(--bs-link-underline-opacity, 1)) !important;
}

.link-danger {
  color: RGBA(var(--bs-danger-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-danger-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-danger:hover, .link-danger:focus {
  color: RGBA(176, 42, 55, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(176, 42, 55, var(--bs-link-underline-opacity, 1)) !important;
}

.link-light {
  color: RGBA(var(--bs-light-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-light-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-light:hover, .link-light:focus {
  color: RGBA(249, 250, 251, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(249, 250, 251, var(--bs-link-underline-opacity, 1)) !important;
}

.link-dark {
  color: RGBA(var(--bs-dark-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-dark-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-dark:hover, .link-dark:focus {
  color: RGBA(26, 30, 33, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(26, 30, 33, var(--bs-link-underline-opacity, 1)) !important;
}

.link-body-emphasis {
  color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-body-emphasis:hover, .link-body-emphasis:focus {
  color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-opacity, 0.75)) !important;
  text-decoration-color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-underline-opacity, 0.75)) !important;
}

.focus-ring:focus {
  outline: 0;
  box-shadow: var(--bs-focus-ring-x, 0) var(--bs-focus-ring-y, 0) var(--bs-focus-ring-blur, 0) var(--bs-focus-ring-width) var(--bs-focus-ring-color);
}

.icon-link {
  display: inline-flex;
  gap: 0.375rem;
  align-items: center;
  text-decoration-color: rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 0.5));
  text-underline-offset: 0.25em;
  backface-visibility: hidden;
}
.icon-link > .bi {
  flex-shrink: 0;
  width: 1em;
  height: 1em;
  fill: currentcolor;
  transition: 0.2s ease-in-out transform;
}
@media (prefers-reduced-motion: reduce) {
  .icon-link > .bi {
    transition: none;
  }
}

.icon-link-hover:hover > .bi, .icon-link-hover:focus-visible > .bi {
  transform: var(--bs-icon-link-transform, translate3d(0.25em, 0, 0));
}

.ratio {
  position: relative;
  width: 100%;
}
.ratio::before {
  display: block;
  padding-top: var(--bs-aspect-ratio);
  content: "";
}
.ratio > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ratio-1x1 {
  --bs-aspect-ratio: 100%;
}

.ratio-4x3 {
  --bs-aspect-ratio: 75%;
}

.ratio-16x9 {
  --bs-aspect-ratio: 56.25%;
}

.ratio-21x9 {
  --bs-aspect-ratio: 42.8571428571%;
}

.fixed-top {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1030;
}

.fixed-bottom {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1030;
}

.sticky-top {
  position: sticky;
  top: 0;
  z-index: 1020;
}

.sticky-bottom {
  position: sticky;
  bottom: 0;
  z-index: 1020;
}

@media (min-width: 576px) {
  .sticky-sm-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-sm-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
@media (min-width: 768px) {
  .sticky-md-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-md-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
@media (min-width: 992px) {
  .sticky-lg-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-lg-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
@media (min-width: 1200px) {
  .sticky-xl-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-xl-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
@media (min-width: 1400px) {
  .sticky-xxl-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-xxl-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
.hstack {
  display: flex;
  flex-direction: row;
  align-items: center;
  align-self: stretch;
}

.vstack {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  align-self: stretch;
}

.visually-hidden,
.visually-hidden-focusable:not(:focus):not(:focus-within) {
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.visually-hidden:not(caption),
.visually-hidden-focusable:not(:focus):not(:focus-within):not(caption) {
  position: absolute !important;
}
.visually-hidden *,
.visually-hidden-focusable:not(:focus):not(:focus-within) * {
  overflow: hidden !important;
}

.stretched-link::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  content: "";
}

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

.vr {
  display: inline-block;
  align-self: stretch;
  width: var(--bs-border-width);
  min-height: 1em;
  background-color: currentcolor;
  opacity: 0.25;
}

.btn {
  --bs-btn-padding-x: 0.75rem;
  --bs-btn-padding-y: 0.375rem;
  --bs-btn-font-family: ;
  --bs-btn-font-size: 1rem;
  --bs-btn-font-weight: 400;
  --bs-btn-line-height: 1.5;
  --bs-btn-color: var(--bs-body-color);
  --bs-btn-bg: transparent;
  --bs-btn-border-width: var(--bs-border-width);
  --bs-btn-border-color: transparent;
  --bs-btn-border-radius: var(--bs-border-radius);
  --bs-btn-hover-border-color: transparent;
  --bs-btn-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075);
  --bs-btn-disabled-opacity: 0.65;
  --bs-btn-focus-box-shadow: 0 0 0 0.25rem rgba(var(--bs-btn-focus-shadow-rgb), .5);
  display: inline-block;
  padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x);
  font-family: var(--bs-btn-font-family);
  font-size: var(--bs-btn-font-size);
  font-weight: var(--bs-btn-font-weight);
  line-height: var(--bs-btn-line-height);
  color: var(--bs-btn-color);
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  user-select: none;
  border: var(--bs-btn-border-width) solid var(--bs-btn-border-color);
  border-radius: var(--bs-btn-border-radius);
  background-color: var(--bs-btn-bg);
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .btn {
    transition: none;
  }
}
.btn:hover {
  color: var(--bs-btn-hover-color);
  background-color: var(--bs-btn-hover-bg);
  border-color: var(--bs-btn-hover-border-color);
}
.btn-check + .btn:hover {
  color: var(--bs-btn-color);
  background-color: var(--bs-btn-bg);
  border-color: var(--bs-btn-border-color);
}
.btn:focus-visible {
  color: var(--bs-btn-hover-color);
  background-color: var(--bs-btn-hover-bg);
  border-color: var(--bs-btn-hover-border-color);
  outline: 0;
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn-check:focus-visible + .btn {
  border-color: var(--bs-btn-hover-border-color);
  outline: 0;
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn-check:checked + .btn, :not(.btn-check) + .btn:active, .btn:first-child:active, .btn.active, .btn.show {
  color: var(--bs-btn-active-color);
  background-color: var(--bs-btn-active-bg);
  border-color: var(--bs-btn-active-border-color);
}
.btn-check:checked + .btn:focus-visible, :not(.btn-check) + .btn:active:focus-visible, .btn:first-child:active:focus-visible, .btn.active:focus-visible, .btn.show:focus-visible {
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn-check:checked:focus-visible + .btn {
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn:disabled, .btn.disabled, fieldset:disabled .btn {
  color: var(--bs-btn-disabled-color);
  pointer-events: none;
  background-color: var(--bs-btn-disabled-bg);
  border-color: var(--bs-btn-disabled-border-color);
  opacity: var(--bs-btn-disabled-opacity);
}

.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: #6a4df5;
  --bs-btn-border-color: #6a4df5;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: rgb(90.1, 65.45, 208.25);
  --bs-btn-hover-border-color: rgb(84.8, 61.6, 196);
  --bs-btn-focus-shadow-rgb: 128, 104, 247;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: rgb(84.8, 61.6, 196);
  --bs-btn-active-border-color: rgb(79.5, 57.75, 183.75);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #6a4df5;
  --bs-btn-disabled-border-color: #6a4df5;
}

.btn-secondary {
  --bs-btn-color: #fff;
  --bs-btn-bg: #1363df;
  --bs-btn-border-color: #1363df;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: rgb(16.15, 84.15, 189.55);
  --bs-btn-hover-border-color: rgb(15.2, 79.2, 178.4);
  --bs-btn-focus-shadow-rgb: 54, 122, 228;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: rgb(15.2, 79.2, 178.4);
  --bs-btn-active-border-color: rgb(14.25, 74.25, 167.25);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #1363df;
  --bs-btn-disabled-border-color: #1363df;
}

.btn-success {
  --bs-btn-color: #fff;
  --bs-btn-bg: #198754;
  --bs-btn-border-color: #198754;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: rgb(21.25, 114.75, 71.4);
  --bs-btn-hover-border-color: rgb(20, 108, 67.2);
  --bs-btn-focus-shadow-rgb: 60, 153, 110;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: rgb(20, 108, 67.2);
  --bs-btn-active-border-color: rgb(18.75, 101.25, 63);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #198754;
  --bs-btn-disabled-border-color: #198754;
}

.btn-info {
  --bs-btn-color: #000;
  --bs-btn-bg: #0dcaf0;
  --bs-btn-border-color: #0dcaf0;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: rgb(49.3, 209.95, 242.25);
  --bs-btn-hover-border-color: rgb(37.2, 207.3, 241.5);
  --bs-btn-focus-shadow-rgb: 11, 172, 204;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: rgb(61.4, 212.6, 243);
  --bs-btn-active-border-color: rgb(37.2, 207.3, 241.5);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #000;
  --bs-btn-disabled-bg: #0dcaf0;
  --bs-btn-disabled-border-color: #0dcaf0;
}

.btn-warning {
  --bs-btn-color: #000;
  --bs-btn-bg: #ffc107;
  --bs-btn-border-color: #ffc107;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: rgb(255, 202.3, 44.2);
  --bs-btn-hover-border-color: rgb(255, 199.2, 31.8);
  --bs-btn-focus-shadow-rgb: 217, 164, 6;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: rgb(255, 205.4, 56.6);
  --bs-btn-active-border-color: rgb(255, 199.2, 31.8);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #000;
  --bs-btn-disabled-bg: #ffc107;
  --bs-btn-disabled-border-color: #ffc107;
}

.btn-danger {
  --bs-btn-color: #fff;
  --bs-btn-bg: #dc3545;
  --bs-btn-border-color: #dc3545;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: rgb(187, 45.05, 58.65);
  --bs-btn-hover-border-color: rgb(176, 42.4, 55.2);
  --bs-btn-focus-shadow-rgb: 225, 83, 97;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: rgb(176, 42.4, 55.2);
  --bs-btn-active-border-color: rgb(165, 39.75, 51.75);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #dc3545;
  --bs-btn-disabled-border-color: #dc3545;
}

.btn-light {
  --bs-btn-color: #000;
  --bs-btn-bg: #f8f9fa;
  --bs-btn-border-color: #f8f9fa;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: rgb(210.8, 211.65, 212.5);
  --bs-btn-hover-border-color: rgb(198.4, 199.2, 200);
  --bs-btn-focus-shadow-rgb: 211, 212, 213;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: rgb(198.4, 199.2, 200);
  --bs-btn-active-border-color: rgb(186, 186.75, 187.5);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #000;
  --bs-btn-disabled-bg: #f8f9fa;
  --bs-btn-disabled-border-color: #f8f9fa;
}

.btn-dark {
  --bs-btn-color: #fff;
  --bs-btn-bg: #212529;
  --bs-btn-border-color: #212529;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: rgb(66.3, 69.7, 73.1);
  --bs-btn-hover-border-color: rgb(55.2, 58.8, 62.4);
  --bs-btn-focus-shadow-rgb: 66, 70, 73;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: rgb(77.4, 80.6, 83.8);
  --bs-btn-active-border-color: rgb(55.2, 58.8, 62.4);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #212529;
  --bs-btn-disabled-border-color: #212529;
}

.btn-outline-primary {
  --bs-btn-color: #6a4df5;
  --bs-btn-border-color: #6a4df5;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #6a4df5;
  --bs-btn-hover-border-color: #6a4df5;
  --bs-btn-focus-shadow-rgb: 106, 77, 245;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #6a4df5;
  --bs-btn-active-border-color: #6a4df5;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #6a4df5;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #6a4df5;
  --bs-gradient: none;
}

.btn-outline-secondary {
  --bs-btn-color: #1363df;
  --bs-btn-border-color: #1363df;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #1363df;
  --bs-btn-hover-border-color: #1363df;
  --bs-btn-focus-shadow-rgb: 19, 99, 223;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #1363df;
  --bs-btn-active-border-color: #1363df;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #1363df;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #1363df;
  --bs-gradient: none;
}

.btn-outline-success {
  --bs-btn-color: #198754;
  --bs-btn-border-color: #198754;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #198754;
  --bs-btn-hover-border-color: #198754;
  --bs-btn-focus-shadow-rgb: 25, 135, 84;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #198754;
  --bs-btn-active-border-color: #198754;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #198754;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #198754;
  --bs-gradient: none;
}

.btn-outline-info {
  --bs-btn-color: #0dcaf0;
  --bs-btn-border-color: #0dcaf0;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: #0dcaf0;
  --bs-btn-hover-border-color: #0dcaf0;
  --bs-btn-focus-shadow-rgb: 13, 202, 240;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: #0dcaf0;
  --bs-btn-active-border-color: #0dcaf0;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #0dcaf0;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #0dcaf0;
  --bs-gradient: none;
}

.btn-outline-warning {
  --bs-btn-color: #ffc107;
  --bs-btn-border-color: #ffc107;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: #ffc107;
  --bs-btn-hover-border-color: #ffc107;
  --bs-btn-focus-shadow-rgb: 255, 193, 7;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: #ffc107;
  --bs-btn-active-border-color: #ffc107;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #ffc107;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #ffc107;
  --bs-gradient: none;
}

.btn-outline-danger {
  --bs-btn-color: #dc3545;
  --bs-btn-border-color: #dc3545;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #dc3545;
  --bs-btn-hover-border-color: #dc3545;
  --bs-btn-focus-shadow-rgb: 220, 53, 69;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #dc3545;
  --bs-btn-active-border-color: #dc3545;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #dc3545;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #dc3545;
  --bs-gradient: none;
}

.btn-outline-light {
  --bs-btn-color: #f8f9fa;
  --bs-btn-border-color: #f8f9fa;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: #f8f9fa;
  --bs-btn-hover-border-color: #f8f9fa;
  --bs-btn-focus-shadow-rgb: 248, 249, 250;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: #f8f9fa;
  --bs-btn-active-border-color: #f8f9fa;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #f8f9fa;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #f8f9fa;
  --bs-gradient: none;
}

.btn-outline-dark {
  --bs-btn-color: #212529;
  --bs-btn-border-color: #212529;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #212529;
  --bs-btn-hover-border-color: #212529;
  --bs-btn-focus-shadow-rgb: 33, 37, 41;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #212529;
  --bs-btn-active-border-color: #212529;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #212529;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #212529;
  --bs-gradient: none;
}

.btn-link {
  --bs-btn-font-weight: 400;
  --bs-btn-color: var(--bs-link-color);
  --bs-btn-bg: transparent;
  --bs-btn-border-color: transparent;
  --bs-btn-hover-color: var(--bs-link-hover-color);
  --bs-btn-hover-border-color: transparent;
  --bs-btn-active-color: var(--bs-link-hover-color);
  --bs-btn-active-border-color: transparent;
  --bs-btn-disabled-color: #6c757d;
  --bs-btn-disabled-border-color: transparent;
  --bs-btn-box-shadow: 0 0 0 #000;
  --bs-btn-focus-shadow-rgb: 128, 104, 247;
  text-decoration: underline;
}
.btn-link:focus-visible {
  color: var(--bs-btn-color);
}
.btn-link:hover {
  color: var(--bs-btn-hover-color);
}

.btn-lg {
  --bs-btn-padding-y: 0.5rem;
  --bs-btn-padding-x: 1rem;
  --bs-btn-font-size: 1.25rem;
  --bs-btn-border-radius: var(--bs-border-radius-lg);
}

.btn-sm {
  --bs-btn-padding-y: 0.25rem;
  --bs-btn-padding-x: 0.5rem;
  --bs-btn-font-size: 0.875rem;
  --bs-btn-border-radius: var(--bs-border-radius-sm);
}

.modal {
  --bs-modal-zindex: 1055;
  --bs-modal-width: 500px;
  --bs-modal-padding: 1rem;
  --bs-modal-margin: 0.5rem;
  --bs-modal-color: var(--bs-body-color);
  --bs-modal-bg: var(--bs-body-bg);
  --bs-modal-border-color: var(--bs-border-color-translucent);
  --bs-modal-border-width: var(--bs-border-width);
  --bs-modal-border-radius: var(--bs-border-radius-lg);
  --bs-modal-box-shadow: var(--bs-box-shadow-sm);
  --bs-modal-inner-border-radius: calc(var(--bs-border-radius-lg) - (var(--bs-border-width)));
  --bs-modal-header-padding-x: 1rem;
  --bs-modal-header-padding-y: 1rem;
  --bs-modal-header-padding: 1rem 1rem;
  --bs-modal-header-border-color: var(--bs-border-color);
  --bs-modal-header-border-width: var(--bs-border-width);
  --bs-modal-title-line-height: 1.5;
  --bs-modal-footer-gap: 0.5rem;
  --bs-modal-footer-bg: ;
  --bs-modal-footer-border-color: var(--bs-border-color);
  --bs-modal-footer-border-width: var(--bs-border-width);
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--bs-modal-zindex);
  display: none;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  outline: 0;
}

.modal-dialog {
  position: relative;
  width: auto;
  margin: var(--bs-modal-margin);
  pointer-events: none;
}
.modal.fade .modal-dialog {
  transform: translate(0, -50px);
  transition: transform 0.3s ease-out;
}
@media (prefers-reduced-motion: reduce) {
  .modal.fade .modal-dialog {
    transition: none;
  }
}
.modal.show .modal-dialog {
  transform: none;
}
.modal.modal-static .modal-dialog {
  transform: scale(1.02);
}

.modal-dialog-scrollable {
  height: calc(100% - var(--bs-modal-margin) * 2);
}
.modal-dialog-scrollable .modal-content {
  max-height: 100%;
  overflow: hidden;
}
.modal-dialog-scrollable .modal-body {
  overflow-y: auto;
}

.modal-dialog-centered {
  display: flex;
  align-items: center;
  min-height: calc(100% - var(--bs-modal-margin) * 2);
}

.modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  color: var(--bs-modal-color);
  pointer-events: auto;
  background-color: var(--bs-modal-bg);
  background-clip: padding-box;
  border: var(--bs-modal-border-width) solid var(--bs-modal-border-color);
  border-radius: var(--bs-modal-border-radius);
  outline: 0;
}

.modal-backdrop {
  --bs-backdrop-zindex: 1050;
  --bs-backdrop-bg: #000;
  --bs-backdrop-opacity: 0.5;
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--bs-backdrop-zindex);
  width: 100vw;
  height: 100vh;
  background-color: var(--bs-backdrop-bg);
}
.modal-backdrop.fade {
  opacity: 0;
}
.modal-backdrop.show {
  opacity: var(--bs-backdrop-opacity);
}

.modal-header {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  padding: var(--bs-modal-header-padding);
  border-bottom: var(--bs-modal-header-border-width) solid var(--bs-modal-header-border-color);
  border-top-left-radius: var(--bs-modal-inner-border-radius);
  border-top-right-radius: var(--bs-modal-inner-border-radius);
}
.modal-header .btn-close {
  padding: calc(var(--bs-modal-header-padding-y) * 0.5) calc(var(--bs-modal-header-padding-x) * 0.5);
  margin-top: calc(-0.5 * var(--bs-modal-header-padding-y));
  margin-right: calc(-0.5 * var(--bs-modal-header-padding-x));
  margin-bottom: calc(-0.5 * var(--bs-modal-header-padding-y));
  margin-left: auto;
}

.modal-title {
  margin-bottom: 0;
  line-height: var(--bs-modal-title-line-height);
}

.modal-body {
  position: relative;
  flex: 1 1 auto;
  padding: var(--bs-modal-padding);
}

.modal-footer {
  display: flex;
  flex-shrink: 0;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  padding: calc(var(--bs-modal-padding) - var(--bs-modal-footer-gap) * 0.5);
  background-color: var(--bs-modal-footer-bg);
  border-top: var(--bs-modal-footer-border-width) solid var(--bs-modal-footer-border-color);
  border-bottom-right-radius: var(--bs-modal-inner-border-radius);
  border-bottom-left-radius: var(--bs-modal-inner-border-radius);
}
.modal-footer > * {
  margin: calc(var(--bs-modal-footer-gap) * 0.5);
}

@media (min-width: 576px) {
  .modal {
    --bs-modal-margin: 1.75rem;
    --bs-modal-box-shadow: var(--bs-box-shadow);
  }
  .modal-dialog {
    max-width: var(--bs-modal-width);
    margin-right: auto;
    margin-left: auto;
  }
  .modal-sm {
    --bs-modal-width: 300px;
  }
}
@media (min-width: 992px) {
  .modal-lg,
  .modal-xl {
    --bs-modal-width: 800px;
  }
}
@media (min-width: 1200px) {
  .modal-xl {
    --bs-modal-width: 1140px;
  }
}
.modal-fullscreen {
  width: 100vw;
  max-width: none;
  height: 100%;
  margin: 0;
}
.modal-fullscreen .modal-content {
  height: 100%;
  border: 0;
  border-radius: 0;
}
.modal-fullscreen .modal-header,
.modal-fullscreen .modal-footer {
  border-radius: 0;
}
.modal-fullscreen .modal-body {
  overflow-y: auto;
}

@media (max-width: 575.98px) {
  .modal-fullscreen-sm-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-sm-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-sm-down .modal-header,
  .modal-fullscreen-sm-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-sm-down .modal-body {
    overflow-y: auto;
  }
}
@media (max-width: 767.98px) {
  .modal-fullscreen-md-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-md-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-md-down .modal-header,
  .modal-fullscreen-md-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-md-down .modal-body {
    overflow-y: auto;
  }
}
@media (max-width: 991.98px) {
  .modal-fullscreen-lg-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-lg-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-lg-down .modal-header,
  .modal-fullscreen-lg-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-lg-down .modal-body {
    overflow-y: auto;
  }
}
@media (max-width: 1199.98px) {
  .modal-fullscreen-xl-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-xl-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-xl-down .modal-header,
  .modal-fullscreen-xl-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-xl-down .modal-body {
    overflow-y: auto;
  }
}
@media (max-width: 1399.98px) {
  .modal-fullscreen-xxl-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-xxl-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-xxl-down .modal-header,
  .modal-fullscreen-xxl-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-xxl-down .modal-body {
    overflow-y: auto;
  }
}
.btn-close {
  --bs-btn-close-color: #000;
  --bs-btn-close-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414'/%3e%3c/svg%3e");
  --bs-btn-close-opacity: 0.5;
  --bs-btn-close-hover-opacity: 0.75;
  --bs-btn-close-focus-shadow: 0 0 0 0.25rem rgba(106, 77, 245, 0.25);
  --bs-btn-close-focus-opacity: 1;
  --bs-btn-close-disabled-opacity: 0.25;
  box-sizing: content-box;
  width: 1em;
  height: 1em;
  padding: 0.25em 0.25em;
  color: var(--bs-btn-close-color);
  background: transparent var(--bs-btn-close-bg) center/1em auto no-repeat;
  filter: var(--bs-btn-close-filter);
  border: 0;
  border-radius: 0.375rem;
  opacity: var(--bs-btn-close-opacity);
}
.btn-close:hover {
  color: var(--bs-btn-close-color);
  text-decoration: none;
  opacity: var(--bs-btn-close-hover-opacity);
}
.btn-close:focus {
  outline: 0;
  box-shadow: var(--bs-btn-close-focus-shadow);
  opacity: var(--bs-btn-close-focus-opacity);
}
.btn-close:disabled, .btn-close.disabled {
  pointer-events: none;
  user-select: none;
  opacity: var(--bs-btn-close-disabled-opacity);
}

.btn-close-white {
  --bs-btn-close-filter: invert(1) grayscale(100%) brightness(200%);
}

:root,
[data-bs-theme=light] {
  --bs-btn-close-filter: ;
}

[data-bs-theme=dark] {
  --bs-btn-close-filter: invert(1) grayscale(100%) brightness(200%);
}

.align-baseline {
  vertical-align: baseline !important;
}

.align-top {
  vertical-align: top !important;
}

.align-middle {
  vertical-align: middle !important;
}

.align-bottom {
  vertical-align: bottom !important;
}

.align-text-bottom {
  vertical-align: text-bottom !important;
}

.align-text-top {
  vertical-align: text-top !important;
}

.float-start {
  float: left !important;
}

.float-end {
  float: right !important;
}

.float-none {
  float: none !important;
}

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

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

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

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

.object-fit-none {
  object-fit: none !important;
}

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

.opacity-25 {
  opacity: 0.25 !important;
}

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

.opacity-75 {
  opacity: 0.75 !important;
}

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

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

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

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

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

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

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

.overflow-x-visible {
  overflow-x: visible !important;
}

.overflow-x-scroll {
  overflow-x: scroll !important;
}

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

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

.overflow-y-visible {
  overflow-y: visible !important;
}

.overflow-y-scroll {
  overflow-y: scroll !important;
}

.d-inline {
  display: inline !important;
}

.d-inline-block {
  display: inline-block !important;
}

.d-block {
  display: block !important;
}

.d-grid {
  display: grid !important;
}

.d-inline-grid {
  display: inline-grid !important;
}

.d-table {
  display: table !important;
}

.d-table-row {
  display: table-row !important;
}

.d-table-cell {
  display: table-cell !important;
}

.d-flex {
  display: flex !important;
}

.d-inline-flex {
  display: inline-flex !important;
}

.d-none {
  display: none !important;
}

.shadow {
  box-shadow: var(--bs-box-shadow) !important;
}

.shadow-sm {
  box-shadow: var(--bs-box-shadow-sm) !important;
}

.shadow-lg {
  box-shadow: var(--bs-box-shadow-lg) !important;
}

.shadow-none {
  box-shadow: none !important;
}

.focus-ring-primary {
  --bs-focus-ring-color: rgba(var(--bs-primary-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-secondary {
  --bs-focus-ring-color: rgba(var(--bs-secondary-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-success {
  --bs-focus-ring-color: rgba(var(--bs-success-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-info {
  --bs-focus-ring-color: rgba(var(--bs-info-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-warning {
  --bs-focus-ring-color: rgba(var(--bs-warning-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-danger {
  --bs-focus-ring-color: rgba(var(--bs-danger-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-light {
  --bs-focus-ring-color: rgba(var(--bs-light-rgb), var(--bs-focus-ring-opacity));
}

.focus-ring-dark {
  --bs-focus-ring-color: rgba(var(--bs-dark-rgb), var(--bs-focus-ring-opacity));
}

.position-static {
  position: static !important;
}

.position-relative {
  position: relative !important;
}

.position-absolute {
  position: absolute !important;
}

.position-fixed {
  position: fixed !important;
}

.position-sticky {
  position: sticky !important;
}

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

.top-50 {
  top: 50% !important;
}

.top-100 {
  top: 100% !important;
}

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

.bottom-50 {
  bottom: 50% !important;
}

.bottom-100 {
  bottom: 100% !important;
}

.start-0 {
  left: 0 !important;
}

.start-50 {
  left: 50% !important;
}

.start-100 {
  left: 100% !important;
}

.end-0 {
  right: 0 !important;
}

.end-50 {
  right: 50% !important;
}

.end-100 {
  right: 100% !important;
}

.translate-middle {
  transform: translate(-50%, -50%) !important;
}

.translate-middle-x {
  transform: translateX(-50%) !important;
}

.translate-middle-y {
  transform: translateY(-50%) !important;
}

.border {
  border: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

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

.border-top {
  border-top: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

.border-top-0 {
  border-top: 0 !important;
}

.border-end {
  border-right: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

.border-end-0 {
  border-right: 0 !important;
}

.border-bottom {
  border-bottom: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

.border-bottom-0 {
  border-bottom: 0 !important;
}

.border-start {
  border-left: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}

.border-start-0 {
  border-left: 0 !important;
}

.border-primary {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-primary-rgb), var(--bs-border-opacity)) !important;
}

.border-secondary {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-secondary-rgb), var(--bs-border-opacity)) !important;
}

.border-success {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-success-rgb), var(--bs-border-opacity)) !important;
}

.border-info {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-info-rgb), var(--bs-border-opacity)) !important;
}

.border-warning {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-warning-rgb), var(--bs-border-opacity)) !important;
}

.border-danger {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-danger-rgb), var(--bs-border-opacity)) !important;
}

.border-light {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-light-rgb), var(--bs-border-opacity)) !important;
}

.border-dark {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-dark-rgb), var(--bs-border-opacity)) !important;
}

.border-black {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-black-rgb), var(--bs-border-opacity)) !important;
}

.border-white {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-white-rgb), var(--bs-border-opacity)) !important;
}

.border-primary-subtle {
  border-color: var(--bs-primary-border-subtle) !important;
}

.border-secondary-subtle {
  border-color: var(--bs-secondary-border-subtle) !important;
}

.border-success-subtle {
  border-color: var(--bs-success-border-subtle) !important;
}

.border-info-subtle {
  border-color: var(--bs-info-border-subtle) !important;
}

.border-warning-subtle {
  border-color: var(--bs-warning-border-subtle) !important;
}

.border-danger-subtle {
  border-color: var(--bs-danger-border-subtle) !important;
}

.border-light-subtle {
  border-color: var(--bs-light-border-subtle) !important;
}

.border-dark-subtle {
  border-color: var(--bs-dark-border-subtle) !important;
}

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

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

.border-3 {
  border-width: 3px !important;
}

.border-4 {
  border-width: 4px !important;
}

.border-5 {
  border-width: 5px !important;
}

.border-opacity-10 {
  --bs-border-opacity: 0.1;
}

.border-opacity-25 {
  --bs-border-opacity: 0.25;
}

.border-opacity-50 {
  --bs-border-opacity: 0.5;
}

.border-opacity-75 {
  --bs-border-opacity: 0.75;
}

.border-opacity-100 {
  --bs-border-opacity: 1;
}

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

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

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

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

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

.mw-100 {
  max-width: 100% !important;
}

.vw-100 {
  width: 100vw !important;
}

.min-vw-100 {
  min-width: 100vw !important;
}

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

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

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

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

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

.mh-100 {
  max-height: 100% !important;
}

.vh-100 {
  height: 100vh !important;
}

.min-vh-100 {
  min-height: 100vh !important;
}

.flex-fill {
  flex: 1 1 auto !important;
}

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

.flex-column {
  flex-direction: column !important;
}

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

.flex-column-reverse {
  flex-direction: column-reverse !important;
}

.flex-grow-0 {
  flex-grow: 0 !important;
}

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

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

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

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

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

.flex-wrap-reverse {
  flex-wrap: wrap-reverse !important;
}

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

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

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

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

.justify-content-around {
  justify-content: space-around !important;
}

.justify-content-evenly {
  justify-content: space-evenly !important;
}

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

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

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

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

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

.align-content-start {
  align-content: flex-start !important;
}

.align-content-end {
  align-content: flex-end !important;
}

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

.align-content-between {
  align-content: space-between !important;
}

.align-content-around {
  align-content: space-around !important;
}

.align-content-stretch {
  align-content: stretch !important;
}

.align-self-auto {
  align-self: auto !important;
}

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

.align-self-end {
  align-self: flex-end !important;
}

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

.align-self-baseline {
  align-self: baseline !important;
}

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

.order-first {
  order: -1 !important;
}

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

.order-1 {
  order: 1 !important;
}

.order-2 {
  order: 2 !important;
}

.order-3 {
  order: 3 !important;
}

.order-4 {
  order: 4 !important;
}

.order-5 {
  order: 5 !important;
}

.order-last {
  order: 6 !important;
}

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

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

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

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

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

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

.m-auto {
  margin: auto !important;
}

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

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

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

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

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

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

.mx-auto {
  margin-right: auto !important;
  margin-left: auto !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: 3rem !important;
  margin-bottom: 3rem !important;
}

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

.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: 3rem !important;
}

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

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

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

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

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

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

.me-5 {
  margin-right: 3rem !important;
}

.me-auto {
  margin-right: auto !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: 3rem !important;
}

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

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

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

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

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

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

.ms-5 {
  margin-left: 3rem !important;
}

.ms-auto {
  margin-left: auto !important;
}

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

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

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

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

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

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

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

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

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

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

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

.px-5 {
  padding-right: 3rem !important;
  padding-left: 3rem !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: 3rem !important;
  padding-bottom: 3rem !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: 3rem !important;
}

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

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

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

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

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

.pe-5 {
  padding-right: 3rem !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: 3rem !important;
}

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

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

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

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

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

.ps-5 {
  padding-left: 3rem !important;
}

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

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

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

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

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

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

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

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

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

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

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

.row-gap-5 {
  row-gap: 3rem !important;
}

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

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

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

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

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

.column-gap-5 {
  column-gap: 3rem !important;
}

.font-monospace {
  font-family: var(--bs-font-monospace) !important;
}

.fs-1 {
  font-size: calc(1.375rem + 1.5vw) !important;
}

.fs-2 {
  font-size: calc(1.325rem + 0.9vw) !important;
}

.fs-3 {
  font-size: calc(1.3rem + 0.6vw) !important;
}

.fs-4 {
  font-size: calc(1.275rem + 0.3vw) !important;
}

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

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

.fst-italic {
  font-style: italic !important;
}

.fst-normal {
  font-style: normal !important;
}

.fw-lighter {
  font-weight: lighter !important;
}

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

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

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

.fw-semibold {
  font-weight: 600 !important;
}

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

.fw-bolder {
  font-weight: bolder !important;
}

.lh-1 {
  line-height: 1 !important;
}

.lh-sm {
  line-height: 1.25 !important;
}

.lh-base {
  line-height: 1.5 !important;
}

.lh-lg {
  line-height: 2 !important;
}

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

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

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

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

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

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

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

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

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

.text-wrap {
  white-space: normal !important;
}

.text-nowrap {
  white-space: nowrap !important;
}

/* rtl:begin:remove */
.text-break {
  word-wrap: break-word !important;
  word-break: break-word !important;
}

/* rtl:end:remove */
.text-primary {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-primary-rgb), var(--bs-text-opacity)) !important;
}

.text-secondary {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-secondary-rgb), var(--bs-text-opacity)) !important;
}

.text-success {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-success-rgb), var(--bs-text-opacity)) !important;
}

.text-info {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-info-rgb), var(--bs-text-opacity)) !important;
}

.text-warning {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-warning-rgb), var(--bs-text-opacity)) !important;
}

.text-danger {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-danger-rgb), var(--bs-text-opacity)) !important;
}

.text-light {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-light-rgb), var(--bs-text-opacity)) !important;
}

.text-dark {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-dark-rgb), var(--bs-text-opacity)) !important;
}

.text-black {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-black-rgb), var(--bs-text-opacity)) !important;
}

.text-white {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-white-rgb), var(--bs-text-opacity)) !important;
}

.text-body {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-body-color-rgb), var(--bs-text-opacity)) !important;
}

.text-muted {
  --bs-text-opacity: 1;
  color: var(--bs-secondary-color) !important;
}

.text-black-50 {
  --bs-text-opacity: 1;
  color: rgba(0, 0, 0, 0.5) !important;
}

.text-white-50 {
  --bs-text-opacity: 1;
  color: rgba(255, 255, 255, 0.5) !important;
}

.text-body-secondary {
  --bs-text-opacity: 1;
  color: var(--bs-secondary-color) !important;
}

.text-body-tertiary {
  --bs-text-opacity: 1;
  color: var(--bs-tertiary-color) !important;
}

.text-body-emphasis {
  --bs-text-opacity: 1;
  color: var(--bs-emphasis-color) !important;
}

.text-reset {
  --bs-text-opacity: 1;
  color: inherit !important;
}

.text-opacity-25 {
  --bs-text-opacity: 0.25;
}

.text-opacity-50 {
  --bs-text-opacity: 0.5;
}

.text-opacity-75 {
  --bs-text-opacity: 0.75;
}

.text-opacity-100 {
  --bs-text-opacity: 1;
}

.text-primary-emphasis {
  color: var(--bs-primary-text-emphasis) !important;
}

.text-secondary-emphasis {
  color: var(--bs-secondary-text-emphasis) !important;
}

.text-success-emphasis {
  color: var(--bs-success-text-emphasis) !important;
}

.text-info-emphasis {
  color: var(--bs-info-text-emphasis) !important;
}

.text-warning-emphasis {
  color: var(--bs-warning-text-emphasis) !important;
}

.text-danger-emphasis {
  color: var(--bs-danger-text-emphasis) !important;
}

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

.text-dark-emphasis {
  color: var(--bs-dark-text-emphasis) !important;
}

.link-opacity-10 {
  --bs-link-opacity: 0.1;
}

.link-opacity-10-hover:hover {
  --bs-link-opacity: 0.1;
}

.link-opacity-25 {
  --bs-link-opacity: 0.25;
}

.link-opacity-25-hover:hover {
  --bs-link-opacity: 0.25;
}

.link-opacity-50 {
  --bs-link-opacity: 0.5;
}

.link-opacity-50-hover:hover {
  --bs-link-opacity: 0.5;
}

.link-opacity-75 {
  --bs-link-opacity: 0.75;
}

.link-opacity-75-hover:hover {
  --bs-link-opacity: 0.75;
}

.link-opacity-100 {
  --bs-link-opacity: 1;
}

.link-opacity-100-hover:hover {
  --bs-link-opacity: 1;
}

.link-offset-1 {
  text-underline-offset: 0.125em !important;
}

.link-offset-1-hover:hover {
  text-underline-offset: 0.125em !important;
}

.link-offset-2 {
  text-underline-offset: 0.25em !important;
}

.link-offset-2-hover:hover {
  text-underline-offset: 0.25em !important;
}

.link-offset-3 {
  text-underline-offset: 0.375em !important;
}

.link-offset-3-hover:hover {
  text-underline-offset: 0.375em !important;
}

.link-underline-primary {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-primary-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-secondary {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-secondary-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-success {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-success-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-info {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-info-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-warning {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-warning-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-danger {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-danger-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-light {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-light-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline-dark {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-dark-rgb), var(--bs-link-underline-opacity)) !important;
}

.link-underline {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-link-color-rgb), var(--bs-link-underline-opacity, 1)) !important;
}

.link-underline-opacity-0 {
  --bs-link-underline-opacity: 0;
}

.link-underline-opacity-0-hover:hover {
  --bs-link-underline-opacity: 0;
}

.link-underline-opacity-10 {
  --bs-link-underline-opacity: 0.1;
}

.link-underline-opacity-10-hover:hover {
  --bs-link-underline-opacity: 0.1;
}

.link-underline-opacity-25 {
  --bs-link-underline-opacity: 0.25;
}

.link-underline-opacity-25-hover:hover {
  --bs-link-underline-opacity: 0.25;
}

.link-underline-opacity-50 {
  --bs-link-underline-opacity: 0.5;
}

.link-underline-opacity-50-hover:hover {
  --bs-link-underline-opacity: 0.5;
}

.link-underline-opacity-75 {
  --bs-link-underline-opacity: 0.75;
}

.link-underline-opacity-75-hover:hover {
  --bs-link-underline-opacity: 0.75;
}

.link-underline-opacity-100 {
  --bs-link-underline-opacity: 1;
}

.link-underline-opacity-100-hover:hover {
  --bs-link-underline-opacity: 1;
}

.bg-primary {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-secondary {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-secondary-rgb), var(--bs-bg-opacity)) !important;
}

.bg-success {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-success-rgb), var(--bs-bg-opacity)) !important;
}

.bg-info {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-info-rgb), var(--bs-bg-opacity)) !important;
}

.bg-warning {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-warning-rgb), var(--bs-bg-opacity)) !important;
}

.bg-danger {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-danger-rgb), var(--bs-bg-opacity)) !important;
}

.bg-light {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-light-rgb), var(--bs-bg-opacity)) !important;
}

.bg-dark {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-dark-rgb), var(--bs-bg-opacity)) !important;
}

.bg-black {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-black-rgb), var(--bs-bg-opacity)) !important;
}

.bg-white {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-white-rgb), var(--bs-bg-opacity)) !important;
}

.bg-body {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-body-bg-rgb), var(--bs-bg-opacity)) !important;
}

.bg-transparent {
  --bs-bg-opacity: 1;
  background-color: transparent !important;
}

.bg-body-secondary {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-secondary-bg-rgb), var(--bs-bg-opacity)) !important;
}

.bg-body-tertiary {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-tertiary-bg-rgb), var(--bs-bg-opacity)) !important;
}

.bg-opacity-10 {
  --bs-bg-opacity: 0.1;
}

.bg-opacity-25 {
  --bs-bg-opacity: 0.25;
}

.bg-opacity-50 {
  --bs-bg-opacity: 0.5;
}

.bg-opacity-75 {
  --bs-bg-opacity: 0.75;
}

.bg-opacity-100 {
  --bs-bg-opacity: 1;
}

.bg-primary-subtle {
  background-color: var(--bs-primary-bg-subtle) !important;
}

.bg-secondary-subtle {
  background-color: var(--bs-secondary-bg-subtle) !important;
}

.bg-success-subtle {
  background-color: var(--bs-success-bg-subtle) !important;
}

.bg-info-subtle {
  background-color: var(--bs-info-bg-subtle) !important;
}

.bg-warning-subtle {
  background-color: var(--bs-warning-bg-subtle) !important;
}

.bg-danger-subtle {
  background-color: var(--bs-danger-bg-subtle) !important;
}

.bg-light-subtle {
  background-color: var(--bs-light-bg-subtle) !important;
}

.bg-dark-subtle {
  background-color: var(--bs-dark-bg-subtle) !important;
}

.bg-gradient {
  background-image: var(--bs-gradient) !important;
}

.user-select-all {
  user-select: all !important;
}

.user-select-auto {
  user-select: auto !important;
}

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

.pe-none {
  pointer-events: none !important;
}

.pe-auto {
  pointer-events: auto !important;
}

.rounded {
  border-radius: var(--bs-border-radius) !important;
}

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

.rounded-1 {
  border-radius: var(--bs-border-radius-sm) !important;
}

.rounded-2 {
  border-radius: var(--bs-border-radius) !important;
}

.rounded-3 {
  border-radius: var(--bs-border-radius-lg) !important;
}

.rounded-4 {
  border-radius: var(--bs-border-radius-xl) !important;
}

.rounded-5 {
  border-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-circle {
  border-radius: 50% !important;
}

.rounded-pill {
  border-radius: var(--bs-border-radius-pill) !important;
}

.rounded-top {
  border-top-left-radius: var(--bs-border-radius) !important;
  border-top-right-radius: var(--bs-border-radius) !important;
}

.rounded-top-0 {
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}

.rounded-top-1 {
  border-top-left-radius: var(--bs-border-radius-sm) !important;
  border-top-right-radius: var(--bs-border-radius-sm) !important;
}

.rounded-top-2 {
  border-top-left-radius: var(--bs-border-radius) !important;
  border-top-right-radius: var(--bs-border-radius) !important;
}

.rounded-top-3 {
  border-top-left-radius: var(--bs-border-radius-lg) !important;
  border-top-right-radius: var(--bs-border-radius-lg) !important;
}

.rounded-top-4 {
  border-top-left-radius: var(--bs-border-radius-xl) !important;
  border-top-right-radius: var(--bs-border-radius-xl) !important;
}

.rounded-top-5 {
  border-top-left-radius: var(--bs-border-radius-xxl) !important;
  border-top-right-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-top-circle {
  border-top-left-radius: 50% !important;
  border-top-right-radius: 50% !important;
}

.rounded-top-pill {
  border-top-left-radius: var(--bs-border-radius-pill) !important;
  border-top-right-radius: var(--bs-border-radius-pill) !important;
}

.rounded-end {
  border-top-right-radius: var(--bs-border-radius) !important;
  border-bottom-right-radius: var(--bs-border-radius) !important;
}

.rounded-end-0 {
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

.rounded-end-1 {
  border-top-right-radius: var(--bs-border-radius-sm) !important;
  border-bottom-right-radius: var(--bs-border-radius-sm) !important;
}

.rounded-end-2 {
  border-top-right-radius: var(--bs-border-radius) !important;
  border-bottom-right-radius: var(--bs-border-radius) !important;
}

.rounded-end-3 {
  border-top-right-radius: var(--bs-border-radius-lg) !important;
  border-bottom-right-radius: var(--bs-border-radius-lg) !important;
}

.rounded-end-4 {
  border-top-right-radius: var(--bs-border-radius-xl) !important;
  border-bottom-right-radius: var(--bs-border-radius-xl) !important;
}

.rounded-end-5 {
  border-top-right-radius: var(--bs-border-radius-xxl) !important;
  border-bottom-right-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-end-circle {
  border-top-right-radius: 50% !important;
  border-bottom-right-radius: 50% !important;
}

.rounded-end-pill {
  border-top-right-radius: var(--bs-border-radius-pill) !important;
  border-bottom-right-radius: var(--bs-border-radius-pill) !important;
}

.rounded-bottom {
  border-bottom-right-radius: var(--bs-border-radius) !important;
  border-bottom-left-radius: var(--bs-border-radius) !important;
}

.rounded-bottom-0 {
  border-bottom-right-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
}

.rounded-bottom-1 {
  border-bottom-right-radius: var(--bs-border-radius-sm) !important;
  border-bottom-left-radius: var(--bs-border-radius-sm) !important;
}

.rounded-bottom-2 {
  border-bottom-right-radius: var(--bs-border-radius) !important;
  border-bottom-left-radius: var(--bs-border-radius) !important;
}

.rounded-bottom-3 {
  border-bottom-right-radius: var(--bs-border-radius-lg) !important;
  border-bottom-left-radius: var(--bs-border-radius-lg) !important;
}

.rounded-bottom-4 {
  border-bottom-right-radius: var(--bs-border-radius-xl) !important;
  border-bottom-left-radius: var(--bs-border-radius-xl) !important;
}

.rounded-bottom-5 {
  border-bottom-right-radius: var(--bs-border-radius-xxl) !important;
  border-bottom-left-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-bottom-circle {
  border-bottom-right-radius: 50% !important;
  border-bottom-left-radius: 50% !important;
}

.rounded-bottom-pill {
  border-bottom-right-radius: var(--bs-border-radius-pill) !important;
  border-bottom-left-radius: var(--bs-border-radius-pill) !important;
}

.rounded-start {
  border-bottom-left-radius: var(--bs-border-radius) !important;
  border-top-left-radius: var(--bs-border-radius) !important;
}

.rounded-start-0 {
  border-bottom-left-radius: 0 !important;
  border-top-left-radius: 0 !important;
}

.rounded-start-1 {
  border-bottom-left-radius: var(--bs-border-radius-sm) !important;
  border-top-left-radius: var(--bs-border-radius-sm) !important;
}

.rounded-start-2 {
  border-bottom-left-radius: var(--bs-border-radius) !important;
  border-top-left-radius: var(--bs-border-radius) !important;
}

.rounded-start-3 {
  border-bottom-left-radius: var(--bs-border-radius-lg) !important;
  border-top-left-radius: var(--bs-border-radius-lg) !important;
}

.rounded-start-4 {
  border-bottom-left-radius: var(--bs-border-radius-xl) !important;
  border-top-left-radius: var(--bs-border-radius-xl) !important;
}

.rounded-start-5 {
  border-bottom-left-radius: var(--bs-border-radius-xxl) !important;
  border-top-left-radius: var(--bs-border-radius-xxl) !important;
}

.rounded-start-circle {
  border-bottom-left-radius: 50% !important;
  border-top-left-radius: 50% !important;
}

.rounded-start-pill {
  border-bottom-left-radius: var(--bs-border-radius-pill) !important;
  border-top-left-radius: var(--bs-border-radius-pill) !important;
}

.visible {
  visibility: visible !important;
}

.invisible {
  visibility: hidden !important;
}

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

.z-0 {
  z-index: 0 !important;
}

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

.z-2 {
  z-index: 2 !important;
}

.z-3 {
  z-index: 3 !important;
}

@media (min-width: 576px) {
  .float-sm-start {
    float: left !important;
  }
  .float-sm-end {
    float: right !important;
  }
  .float-sm-none {
    float: none !important;
  }
  .object-fit-sm-contain {
    object-fit: contain !important;
  }
  .object-fit-sm-cover {
    object-fit: cover !important;
  }
  .object-fit-sm-fill {
    object-fit: fill !important;
  }
  .object-fit-sm-scale {
    object-fit: scale-down !important;
  }
  .object-fit-sm-none {
    object-fit: none !important;
  }
  .d-sm-inline {
    display: inline !important;
  }
  .d-sm-inline-block {
    display: inline-block !important;
  }
  .d-sm-block {
    display: block !important;
  }
  .d-sm-grid {
    display: grid !important;
  }
  .d-sm-inline-grid {
    display: inline-grid !important;
  }
  .d-sm-table {
    display: table !important;
  }
  .d-sm-table-row {
    display: table-row !important;
  }
  .d-sm-table-cell {
    display: table-cell !important;
  }
  .d-sm-flex {
    display: flex !important;
  }
  .d-sm-inline-flex {
    display: inline-flex !important;
  }
  .d-sm-none {
    display: none !important;
  }
  .flex-sm-fill {
    flex: 1 1 auto !important;
  }
  .flex-sm-row {
    flex-direction: row !important;
  }
  .flex-sm-column {
    flex-direction: column !important;
  }
  .flex-sm-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-sm-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-sm-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-sm-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-sm-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-sm-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-sm-wrap {
    flex-wrap: wrap !important;
  }
  .flex-sm-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-sm-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-sm-start {
    justify-content: flex-start !important;
  }
  .justify-content-sm-end {
    justify-content: flex-end !important;
  }
  .justify-content-sm-center {
    justify-content: center !important;
  }
  .justify-content-sm-between {
    justify-content: space-between !important;
  }
  .justify-content-sm-around {
    justify-content: space-around !important;
  }
  .justify-content-sm-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-sm-start {
    align-items: flex-start !important;
  }
  .align-items-sm-end {
    align-items: flex-end !important;
  }
  .align-items-sm-center {
    align-items: center !important;
  }
  .align-items-sm-baseline {
    align-items: baseline !important;
  }
  .align-items-sm-stretch {
    align-items: stretch !important;
  }
  .align-content-sm-start {
    align-content: flex-start !important;
  }
  .align-content-sm-end {
    align-content: flex-end !important;
  }
  .align-content-sm-center {
    align-content: center !important;
  }
  .align-content-sm-between {
    align-content: space-between !important;
  }
  .align-content-sm-around {
    align-content: space-around !important;
  }
  .align-content-sm-stretch {
    align-content: stretch !important;
  }
  .align-self-sm-auto {
    align-self: auto !important;
  }
  .align-self-sm-start {
    align-self: flex-start !important;
  }
  .align-self-sm-end {
    align-self: flex-end !important;
  }
  .align-self-sm-center {
    align-self: center !important;
  }
  .align-self-sm-baseline {
    align-self: baseline !important;
  }
  .align-self-sm-stretch {
    align-self: stretch !important;
  }
  .order-sm-first {
    order: -1 !important;
  }
  .order-sm-0 {
    order: 0 !important;
  }
  .order-sm-1 {
    order: 1 !important;
  }
  .order-sm-2 {
    order: 2 !important;
  }
  .order-sm-3 {
    order: 3 !important;
  }
  .order-sm-4 {
    order: 4 !important;
  }
  .order-sm-5 {
    order: 5 !important;
  }
  .order-sm-last {
    order: 6 !important;
  }
  .m-sm-0 {
    margin: 0 !important;
  }
  .m-sm-1 {
    margin: 0.25rem !important;
  }
  .m-sm-2 {
    margin: 0.5rem !important;
  }
  .m-sm-3 {
    margin: 1rem !important;
  }
  .m-sm-4 {
    margin: 1.5rem !important;
  }
  .m-sm-5 {
    margin: 3rem !important;
  }
  .m-sm-auto {
    margin: auto !important;
  }
  .mx-sm-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-sm-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-sm-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-sm-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-sm-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-sm-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-sm-auto {
    margin-right: auto !important;
    margin-left: auto !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: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-sm-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .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: 3rem !important;
  }
  .mt-sm-auto {
    margin-top: auto !important;
  }
  .me-sm-0 {
    margin-right: 0 !important;
  }
  .me-sm-1 {
    margin-right: 0.25rem !important;
  }
  .me-sm-2 {
    margin-right: 0.5rem !important;
  }
  .me-sm-3 {
    margin-right: 1rem !important;
  }
  .me-sm-4 {
    margin-right: 1.5rem !important;
  }
  .me-sm-5 {
    margin-right: 3rem !important;
  }
  .me-sm-auto {
    margin-right: auto !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: 3rem !important;
  }
  .mb-sm-auto {
    margin-bottom: auto !important;
  }
  .ms-sm-0 {
    margin-left: 0 !important;
  }
  .ms-sm-1 {
    margin-left: 0.25rem !important;
  }
  .ms-sm-2 {
    margin-left: 0.5rem !important;
  }
  .ms-sm-3 {
    margin-left: 1rem !important;
  }
  .ms-sm-4 {
    margin-left: 1.5rem !important;
  }
  .ms-sm-5 {
    margin-left: 3rem !important;
  }
  .ms-sm-auto {
    margin-left: auto !important;
  }
  .p-sm-0 {
    padding: 0 !important;
  }
  .p-sm-1 {
    padding: 0.25rem !important;
  }
  .p-sm-2 {
    padding: 0.5rem !important;
  }
  .p-sm-3 {
    padding: 1rem !important;
  }
  .p-sm-4 {
    padding: 1.5rem !important;
  }
  .p-sm-5 {
    padding: 3rem !important;
  }
  .px-sm-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-sm-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-sm-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-sm-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-sm-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-sm-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !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: 3rem !important;
    padding-bottom: 3rem !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: 3rem !important;
  }
  .pe-sm-0 {
    padding-right: 0 !important;
  }
  .pe-sm-1 {
    padding-right: 0.25rem !important;
  }
  .pe-sm-2 {
    padding-right: 0.5rem !important;
  }
  .pe-sm-3 {
    padding-right: 1rem !important;
  }
  .pe-sm-4 {
    padding-right: 1.5rem !important;
  }
  .pe-sm-5 {
    padding-right: 3rem !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: 3rem !important;
  }
  .ps-sm-0 {
    padding-left: 0 !important;
  }
  .ps-sm-1 {
    padding-left: 0.25rem !important;
  }
  .ps-sm-2 {
    padding-left: 0.5rem !important;
  }
  .ps-sm-3 {
    padding-left: 1rem !important;
  }
  .ps-sm-4 {
    padding-left: 1.5rem !important;
  }
  .ps-sm-5 {
    padding-left: 3rem !important;
  }
  .gap-sm-0 {
    gap: 0 !important;
  }
  .gap-sm-1 {
    gap: 0.25rem !important;
  }
  .gap-sm-2 {
    gap: 0.5rem !important;
  }
  .gap-sm-3 {
    gap: 1rem !important;
  }
  .gap-sm-4 {
    gap: 1.5rem !important;
  }
  .gap-sm-5 {
    gap: 3rem !important;
  }
  .row-gap-sm-0 {
    row-gap: 0 !important;
  }
  .row-gap-sm-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-sm-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-sm-3 {
    row-gap: 1rem !important;
  }
  .row-gap-sm-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-sm-5 {
    row-gap: 3rem !important;
  }
  .column-gap-sm-0 {
    column-gap: 0 !important;
  }
  .column-gap-sm-1 {
    column-gap: 0.25rem !important;
  }
  .column-gap-sm-2 {
    column-gap: 0.5rem !important;
  }
  .column-gap-sm-3 {
    column-gap: 1rem !important;
  }
  .column-gap-sm-4 {
    column-gap: 1.5rem !important;
  }
  .column-gap-sm-5 {
    column-gap: 3rem !important;
  }
  .text-sm-start {
    text-align: left !important;
  }
  .text-sm-end {
    text-align: right !important;
  }
  .text-sm-center {
    text-align: center !important;
  }
}
@media (min-width: 768px) {
  .float-md-start {
    float: left !important;
  }
  .float-md-end {
    float: right !important;
  }
  .float-md-none {
    float: none !important;
  }
  .object-fit-md-contain {
    object-fit: contain !important;
  }
  .object-fit-md-cover {
    object-fit: cover !important;
  }
  .object-fit-md-fill {
    object-fit: fill !important;
  }
  .object-fit-md-scale {
    object-fit: scale-down !important;
  }
  .object-fit-md-none {
    object-fit: none !important;
  }
  .d-md-inline {
    display: inline !important;
  }
  .d-md-inline-block {
    display: inline-block !important;
  }
  .d-md-block {
    display: block !important;
  }
  .d-md-grid {
    display: grid !important;
  }
  .d-md-inline-grid {
    display: inline-grid !important;
  }
  .d-md-table {
    display: table !important;
  }
  .d-md-table-row {
    display: table-row !important;
  }
  .d-md-table-cell {
    display: table-cell !important;
  }
  .d-md-flex {
    display: flex !important;
  }
  .d-md-inline-flex {
    display: inline-flex !important;
  }
  .d-md-none {
    display: none !important;
  }
  .flex-md-fill {
    flex: 1 1 auto !important;
  }
  .flex-md-row {
    flex-direction: row !important;
  }
  .flex-md-column {
    flex-direction: column !important;
  }
  .flex-md-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-md-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-md-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-md-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-md-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-md-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-md-wrap {
    flex-wrap: wrap !important;
  }
  .flex-md-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-md-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-md-start {
    justify-content: flex-start !important;
  }
  .justify-content-md-end {
    justify-content: flex-end !important;
  }
  .justify-content-md-center {
    justify-content: center !important;
  }
  .justify-content-md-between {
    justify-content: space-between !important;
  }
  .justify-content-md-around {
    justify-content: space-around !important;
  }
  .justify-content-md-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-md-start {
    align-items: flex-start !important;
  }
  .align-items-md-end {
    align-items: flex-end !important;
  }
  .align-items-md-center {
    align-items: center !important;
  }
  .align-items-md-baseline {
    align-items: baseline !important;
  }
  .align-items-md-stretch {
    align-items: stretch !important;
  }
  .align-content-md-start {
    align-content: flex-start !important;
  }
  .align-content-md-end {
    align-content: flex-end !important;
  }
  .align-content-md-center {
    align-content: center !important;
  }
  .align-content-md-between {
    align-content: space-between !important;
  }
  .align-content-md-around {
    align-content: space-around !important;
  }
  .align-content-md-stretch {
    align-content: stretch !important;
  }
  .align-self-md-auto {
    align-self: auto !important;
  }
  .align-self-md-start {
    align-self: flex-start !important;
  }
  .align-self-md-end {
    align-self: flex-end !important;
  }
  .align-self-md-center {
    align-self: center !important;
  }
  .align-self-md-baseline {
    align-self: baseline !important;
  }
  .align-self-md-stretch {
    align-self: stretch !important;
  }
  .order-md-first {
    order: -1 !important;
  }
  .order-md-0 {
    order: 0 !important;
  }
  .order-md-1 {
    order: 1 !important;
  }
  .order-md-2 {
    order: 2 !important;
  }
  .order-md-3 {
    order: 3 !important;
  }
  .order-md-4 {
    order: 4 !important;
  }
  .order-md-5 {
    order: 5 !important;
  }
  .order-md-last {
    order: 6 !important;
  }
  .m-md-0 {
    margin: 0 !important;
  }
  .m-md-1 {
    margin: 0.25rem !important;
  }
  .m-md-2 {
    margin: 0.5rem !important;
  }
  .m-md-3 {
    margin: 1rem !important;
  }
  .m-md-4 {
    margin: 1.5rem !important;
  }
  .m-md-5 {
    margin: 3rem !important;
  }
  .m-md-auto {
    margin: auto !important;
  }
  .mx-md-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-md-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-md-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-md-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-md-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-md-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-md-auto {
    margin-right: auto !important;
    margin-left: auto !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: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-md-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .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: 3rem !important;
  }
  .mt-md-auto {
    margin-top: auto !important;
  }
  .me-md-0 {
    margin-right: 0 !important;
  }
  .me-md-1 {
    margin-right: 0.25rem !important;
  }
  .me-md-2 {
    margin-right: 0.5rem !important;
  }
  .me-md-3 {
    margin-right: 1rem !important;
  }
  .me-md-4 {
    margin-right: 1.5rem !important;
  }
  .me-md-5 {
    margin-right: 3rem !important;
  }
  .me-md-auto {
    margin-right: auto !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: 3rem !important;
  }
  .mb-md-auto {
    margin-bottom: auto !important;
  }
  .ms-md-0 {
    margin-left: 0 !important;
  }
  .ms-md-1 {
    margin-left: 0.25rem !important;
  }
  .ms-md-2 {
    margin-left: 0.5rem !important;
  }
  .ms-md-3 {
    margin-left: 1rem !important;
  }
  .ms-md-4 {
    margin-left: 1.5rem !important;
  }
  .ms-md-5 {
    margin-left: 3rem !important;
  }
  .ms-md-auto {
    margin-left: auto !important;
  }
  .p-md-0 {
    padding: 0 !important;
  }
  .p-md-1 {
    padding: 0.25rem !important;
  }
  .p-md-2 {
    padding: 0.5rem !important;
  }
  .p-md-3 {
    padding: 1rem !important;
  }
  .p-md-4 {
    padding: 1.5rem !important;
  }
  .p-md-5 {
    padding: 3rem !important;
  }
  .px-md-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-md-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-md-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-md-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-md-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-md-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !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: 3rem !important;
    padding-bottom: 3rem !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: 3rem !important;
  }
  .pe-md-0 {
    padding-right: 0 !important;
  }
  .pe-md-1 {
    padding-right: 0.25rem !important;
  }
  .pe-md-2 {
    padding-right: 0.5rem !important;
  }
  .pe-md-3 {
    padding-right: 1rem !important;
  }
  .pe-md-4 {
    padding-right: 1.5rem !important;
  }
  .pe-md-5 {
    padding-right: 3rem !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: 3rem !important;
  }
  .ps-md-0 {
    padding-left: 0 !important;
  }
  .ps-md-1 {
    padding-left: 0.25rem !important;
  }
  .ps-md-2 {
    padding-left: 0.5rem !important;
  }
  .ps-md-3 {
    padding-left: 1rem !important;
  }
  .ps-md-4 {
    padding-left: 1.5rem !important;
  }
  .ps-md-5 {
    padding-left: 3rem !important;
  }
  .gap-md-0 {
    gap: 0 !important;
  }
  .gap-md-1 {
    gap: 0.25rem !important;
  }
  .gap-md-2 {
    gap: 0.5rem !important;
  }
  .gap-md-3 {
    gap: 1rem !important;
  }
  .gap-md-4 {
    gap: 1.5rem !important;
  }
  .gap-md-5 {
    gap: 3rem !important;
  }
  .row-gap-md-0 {
    row-gap: 0 !important;
  }
  .row-gap-md-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-md-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-md-3 {
    row-gap: 1rem !important;
  }
  .row-gap-md-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-md-5 {
    row-gap: 3rem !important;
  }
  .column-gap-md-0 {
    column-gap: 0 !important;
  }
  .column-gap-md-1 {
    column-gap: 0.25rem !important;
  }
  .column-gap-md-2 {
    column-gap: 0.5rem !important;
  }
  .column-gap-md-3 {
    column-gap: 1rem !important;
  }
  .column-gap-md-4 {
    column-gap: 1.5rem !important;
  }
  .column-gap-md-5 {
    column-gap: 3rem !important;
  }
  .text-md-start {
    text-align: left !important;
  }
  .text-md-end {
    text-align: right !important;
  }
  .text-md-center {
    text-align: center !important;
  }
}
@media (min-width: 992px) {
  .float-lg-start {
    float: left !important;
  }
  .float-lg-end {
    float: right !important;
  }
  .float-lg-none {
    float: none !important;
  }
  .object-fit-lg-contain {
    object-fit: contain !important;
  }
  .object-fit-lg-cover {
    object-fit: cover !important;
  }
  .object-fit-lg-fill {
    object-fit: fill !important;
  }
  .object-fit-lg-scale {
    object-fit: scale-down !important;
  }
  .object-fit-lg-none {
    object-fit: none !important;
  }
  .d-lg-inline {
    display: inline !important;
  }
  .d-lg-inline-block {
    display: inline-block !important;
  }
  .d-lg-block {
    display: block !important;
  }
  .d-lg-grid {
    display: grid !important;
  }
  .d-lg-inline-grid {
    display: inline-grid !important;
  }
  .d-lg-table {
    display: table !important;
  }
  .d-lg-table-row {
    display: table-row !important;
  }
  .d-lg-table-cell {
    display: table-cell !important;
  }
  .d-lg-flex {
    display: flex !important;
  }
  .d-lg-inline-flex {
    display: inline-flex !important;
  }
  .d-lg-none {
    display: none !important;
  }
  .flex-lg-fill {
    flex: 1 1 auto !important;
  }
  .flex-lg-row {
    flex-direction: row !important;
  }
  .flex-lg-column {
    flex-direction: column !important;
  }
  .flex-lg-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-lg-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-lg-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-lg-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-lg-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-lg-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-lg-wrap {
    flex-wrap: wrap !important;
  }
  .flex-lg-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-lg-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-lg-start {
    justify-content: flex-start !important;
  }
  .justify-content-lg-end {
    justify-content: flex-end !important;
  }
  .justify-content-lg-center {
    justify-content: center !important;
  }
  .justify-content-lg-between {
    justify-content: space-between !important;
  }
  .justify-content-lg-around {
    justify-content: space-around !important;
  }
  .justify-content-lg-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-lg-start {
    align-items: flex-start !important;
  }
  .align-items-lg-end {
    align-items: flex-end !important;
  }
  .align-items-lg-center {
    align-items: center !important;
  }
  .align-items-lg-baseline {
    align-items: baseline !important;
  }
  .align-items-lg-stretch {
    align-items: stretch !important;
  }
  .align-content-lg-start {
    align-content: flex-start !important;
  }
  .align-content-lg-end {
    align-content: flex-end !important;
  }
  .align-content-lg-center {
    align-content: center !important;
  }
  .align-content-lg-between {
    align-content: space-between !important;
  }
  .align-content-lg-around {
    align-content: space-around !important;
  }
  .align-content-lg-stretch {
    align-content: stretch !important;
  }
  .align-self-lg-auto {
    align-self: auto !important;
  }
  .align-self-lg-start {
    align-self: flex-start !important;
  }
  .align-self-lg-end {
    align-self: flex-end !important;
  }
  .align-self-lg-center {
    align-self: center !important;
  }
  .align-self-lg-baseline {
    align-self: baseline !important;
  }
  .align-self-lg-stretch {
    align-self: stretch !important;
  }
  .order-lg-first {
    order: -1 !important;
  }
  .order-lg-0 {
    order: 0 !important;
  }
  .order-lg-1 {
    order: 1 !important;
  }
  .order-lg-2 {
    order: 2 !important;
  }
  .order-lg-3 {
    order: 3 !important;
  }
  .order-lg-4 {
    order: 4 !important;
  }
  .order-lg-5 {
    order: 5 !important;
  }
  .order-lg-last {
    order: 6 !important;
  }
  .m-lg-0 {
    margin: 0 !important;
  }
  .m-lg-1 {
    margin: 0.25rem !important;
  }
  .m-lg-2 {
    margin: 0.5rem !important;
  }
  .m-lg-3 {
    margin: 1rem !important;
  }
  .m-lg-4 {
    margin: 1.5rem !important;
  }
  .m-lg-5 {
    margin: 3rem !important;
  }
  .m-lg-auto {
    margin: auto !important;
  }
  .mx-lg-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-lg-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-lg-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-lg-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-lg-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-lg-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-lg-auto {
    margin-right: auto !important;
    margin-left: auto !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: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-lg-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .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: 3rem !important;
  }
  .mt-lg-auto {
    margin-top: auto !important;
  }
  .me-lg-0 {
    margin-right: 0 !important;
  }
  .me-lg-1 {
    margin-right: 0.25rem !important;
  }
  .me-lg-2 {
    margin-right: 0.5rem !important;
  }
  .me-lg-3 {
    margin-right: 1rem !important;
  }
  .me-lg-4 {
    margin-right: 1.5rem !important;
  }
  .me-lg-5 {
    margin-right: 3rem !important;
  }
  .me-lg-auto {
    margin-right: auto !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: 3rem !important;
  }
  .mb-lg-auto {
    margin-bottom: auto !important;
  }
  .ms-lg-0 {
    margin-left: 0 !important;
  }
  .ms-lg-1 {
    margin-left: 0.25rem !important;
  }
  .ms-lg-2 {
    margin-left: 0.5rem !important;
  }
  .ms-lg-3 {
    margin-left: 1rem !important;
  }
  .ms-lg-4 {
    margin-left: 1.5rem !important;
  }
  .ms-lg-5 {
    margin-left: 3rem !important;
  }
  .ms-lg-auto {
    margin-left: auto !important;
  }
  .p-lg-0 {
    padding: 0 !important;
  }
  .p-lg-1 {
    padding: 0.25rem !important;
  }
  .p-lg-2 {
    padding: 0.5rem !important;
  }
  .p-lg-3 {
    padding: 1rem !important;
  }
  .p-lg-4 {
    padding: 1.5rem !important;
  }
  .p-lg-5 {
    padding: 3rem !important;
  }
  .px-lg-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-lg-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-lg-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-lg-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-lg-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-lg-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !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: 3rem !important;
    padding-bottom: 3rem !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: 3rem !important;
  }
  .pe-lg-0 {
    padding-right: 0 !important;
  }
  .pe-lg-1 {
    padding-right: 0.25rem !important;
  }
  .pe-lg-2 {
    padding-right: 0.5rem !important;
  }
  .pe-lg-3 {
    padding-right: 1rem !important;
  }
  .pe-lg-4 {
    padding-right: 1.5rem !important;
  }
  .pe-lg-5 {
    padding-right: 3rem !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: 3rem !important;
  }
  .ps-lg-0 {
    padding-left: 0 !important;
  }
  .ps-lg-1 {
    padding-left: 0.25rem !important;
  }
  .ps-lg-2 {
    padding-left: 0.5rem !important;
  }
  .ps-lg-3 {
    padding-left: 1rem !important;
  }
  .ps-lg-4 {
    padding-left: 1.5rem !important;
  }
  .ps-lg-5 {
    padding-left: 3rem !important;
  }
  .gap-lg-0 {
    gap: 0 !important;
  }
  .gap-lg-1 {
    gap: 0.25rem !important;
  }
  .gap-lg-2 {
    gap: 0.5rem !important;
  }
  .gap-lg-3 {
    gap: 1rem !important;
  }
  .gap-lg-4 {
    gap: 1.5rem !important;
  }
  .gap-lg-5 {
    gap: 3rem !important;
  }
  .row-gap-lg-0 {
    row-gap: 0 !important;
  }
  .row-gap-lg-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-lg-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-lg-3 {
    row-gap: 1rem !important;
  }
  .row-gap-lg-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-lg-5 {
    row-gap: 3rem !important;
  }
  .column-gap-lg-0 {
    column-gap: 0 !important;
  }
  .column-gap-lg-1 {
    column-gap: 0.25rem !important;
  }
  .column-gap-lg-2 {
    column-gap: 0.5rem !important;
  }
  .column-gap-lg-3 {
    column-gap: 1rem !important;
  }
  .column-gap-lg-4 {
    column-gap: 1.5rem !important;
  }
  .column-gap-lg-5 {
    column-gap: 3rem !important;
  }
  .text-lg-start {
    text-align: left !important;
  }
  .text-lg-end {
    text-align: right !important;
  }
  .text-lg-center {
    text-align: center !important;
  }
}
@media (min-width: 1200px) {
  .float-xl-start {
    float: left !important;
  }
  .float-xl-end {
    float: right !important;
  }
  .float-xl-none {
    float: none !important;
  }
  .object-fit-xl-contain {
    object-fit: contain !important;
  }
  .object-fit-xl-cover {
    object-fit: cover !important;
  }
  .object-fit-xl-fill {
    object-fit: fill !important;
  }
  .object-fit-xl-scale {
    object-fit: scale-down !important;
  }
  .object-fit-xl-none {
    object-fit: none !important;
  }
  .d-xl-inline {
    display: inline !important;
  }
  .d-xl-inline-block {
    display: inline-block !important;
  }
  .d-xl-block {
    display: block !important;
  }
  .d-xl-grid {
    display: grid !important;
  }
  .d-xl-inline-grid {
    display: inline-grid !important;
  }
  .d-xl-table {
    display: table !important;
  }
  .d-xl-table-row {
    display: table-row !important;
  }
  .d-xl-table-cell {
    display: table-cell !important;
  }
  .d-xl-flex {
    display: flex !important;
  }
  .d-xl-inline-flex {
    display: inline-flex !important;
  }
  .d-xl-none {
    display: none !important;
  }
  .flex-xl-fill {
    flex: 1 1 auto !important;
  }
  .flex-xl-row {
    flex-direction: row !important;
  }
  .flex-xl-column {
    flex-direction: column !important;
  }
  .flex-xl-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-xl-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-xl-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-xl-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-xl-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-xl-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-xl-wrap {
    flex-wrap: wrap !important;
  }
  .flex-xl-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-xl-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-xl-start {
    justify-content: flex-start !important;
  }
  .justify-content-xl-end {
    justify-content: flex-end !important;
  }
  .justify-content-xl-center {
    justify-content: center !important;
  }
  .justify-content-xl-between {
    justify-content: space-between !important;
  }
  .justify-content-xl-around {
    justify-content: space-around !important;
  }
  .justify-content-xl-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-xl-start {
    align-items: flex-start !important;
  }
  .align-items-xl-end {
    align-items: flex-end !important;
  }
  .align-items-xl-center {
    align-items: center !important;
  }
  .align-items-xl-baseline {
    align-items: baseline !important;
  }
  .align-items-xl-stretch {
    align-items: stretch !important;
  }
  .align-content-xl-start {
    align-content: flex-start !important;
  }
  .align-content-xl-end {
    align-content: flex-end !important;
  }
  .align-content-xl-center {
    align-content: center !important;
  }
  .align-content-xl-between {
    align-content: space-between !important;
  }
  .align-content-xl-around {
    align-content: space-around !important;
  }
  .align-content-xl-stretch {
    align-content: stretch !important;
  }
  .align-self-xl-auto {
    align-self: auto !important;
  }
  .align-self-xl-start {
    align-self: flex-start !important;
  }
  .align-self-xl-end {
    align-self: flex-end !important;
  }
  .align-self-xl-center {
    align-self: center !important;
  }
  .align-self-xl-baseline {
    align-self: baseline !important;
  }
  .align-self-xl-stretch {
    align-self: stretch !important;
  }
  .order-xl-first {
    order: -1 !important;
  }
  .order-xl-0 {
    order: 0 !important;
  }
  .order-xl-1 {
    order: 1 !important;
  }
  .order-xl-2 {
    order: 2 !important;
  }
  .order-xl-3 {
    order: 3 !important;
  }
  .order-xl-4 {
    order: 4 !important;
  }
  .order-xl-5 {
    order: 5 !important;
  }
  .order-xl-last {
    order: 6 !important;
  }
  .m-xl-0 {
    margin: 0 !important;
  }
  .m-xl-1 {
    margin: 0.25rem !important;
  }
  .m-xl-2 {
    margin: 0.5rem !important;
  }
  .m-xl-3 {
    margin: 1rem !important;
  }
  .m-xl-4 {
    margin: 1.5rem !important;
  }
  .m-xl-5 {
    margin: 3rem !important;
  }
  .m-xl-auto {
    margin: auto !important;
  }
  .mx-xl-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-xl-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-xl-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-xl-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-xl-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-xl-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-xl-auto {
    margin-right: auto !important;
    margin-left: auto !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: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-xl-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .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: 3rem !important;
  }
  .mt-xl-auto {
    margin-top: auto !important;
  }
  .me-xl-0 {
    margin-right: 0 !important;
  }
  .me-xl-1 {
    margin-right: 0.25rem !important;
  }
  .me-xl-2 {
    margin-right: 0.5rem !important;
  }
  .me-xl-3 {
    margin-right: 1rem !important;
  }
  .me-xl-4 {
    margin-right: 1.5rem !important;
  }
  .me-xl-5 {
    margin-right: 3rem !important;
  }
  .me-xl-auto {
    margin-right: auto !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: 3rem !important;
  }
  .mb-xl-auto {
    margin-bottom: auto !important;
  }
  .ms-xl-0 {
    margin-left: 0 !important;
  }
  .ms-xl-1 {
    margin-left: 0.25rem !important;
  }
  .ms-xl-2 {
    margin-left: 0.5rem !important;
  }
  .ms-xl-3 {
    margin-left: 1rem !important;
  }
  .ms-xl-4 {
    margin-left: 1.5rem !important;
  }
  .ms-xl-5 {
    margin-left: 3rem !important;
  }
  .ms-xl-auto {
    margin-left: auto !important;
  }
  .p-xl-0 {
    padding: 0 !important;
  }
  .p-xl-1 {
    padding: 0.25rem !important;
  }
  .p-xl-2 {
    padding: 0.5rem !important;
  }
  .p-xl-3 {
    padding: 1rem !important;
  }
  .p-xl-4 {
    padding: 1.5rem !important;
  }
  .p-xl-5 {
    padding: 3rem !important;
  }
  .px-xl-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-xl-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-xl-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-xl-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-xl-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-xl-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !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: 3rem !important;
    padding-bottom: 3rem !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: 3rem !important;
  }
  .pe-xl-0 {
    padding-right: 0 !important;
  }
  .pe-xl-1 {
    padding-right: 0.25rem !important;
  }
  .pe-xl-2 {
    padding-right: 0.5rem !important;
  }
  .pe-xl-3 {
    padding-right: 1rem !important;
  }
  .pe-xl-4 {
    padding-right: 1.5rem !important;
  }
  .pe-xl-5 {
    padding-right: 3rem !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: 3rem !important;
  }
  .ps-xl-0 {
    padding-left: 0 !important;
  }
  .ps-xl-1 {
    padding-left: 0.25rem !important;
  }
  .ps-xl-2 {
    padding-left: 0.5rem !important;
  }
  .ps-xl-3 {
    padding-left: 1rem !important;
  }
  .ps-xl-4 {
    padding-left: 1.5rem !important;
  }
  .ps-xl-5 {
    padding-left: 3rem !important;
  }
  .gap-xl-0 {
    gap: 0 !important;
  }
  .gap-xl-1 {
    gap: 0.25rem !important;
  }
  .gap-xl-2 {
    gap: 0.5rem !important;
  }
  .gap-xl-3 {
    gap: 1rem !important;
  }
  .gap-xl-4 {
    gap: 1.5rem !important;
  }
  .gap-xl-5 {
    gap: 3rem !important;
  }
  .row-gap-xl-0 {
    row-gap: 0 !important;
  }
  .row-gap-xl-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-xl-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-xl-3 {
    row-gap: 1rem !important;
  }
  .row-gap-xl-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-xl-5 {
    row-gap: 3rem !important;
  }
  .column-gap-xl-0 {
    column-gap: 0 !important;
  }
  .column-gap-xl-1 {
    column-gap: 0.25rem !important;
  }
  .column-gap-xl-2 {
    column-gap: 0.5rem !important;
  }
  .column-gap-xl-3 {
    column-gap: 1rem !important;
  }
  .column-gap-xl-4 {
    column-gap: 1.5rem !important;
  }
  .column-gap-xl-5 {
    column-gap: 3rem !important;
  }
  .text-xl-start {
    text-align: left !important;
  }
  .text-xl-end {
    text-align: right !important;
  }
  .text-xl-center {
    text-align: center !important;
  }
}
@media (min-width: 1400px) {
  .float-xxl-start {
    float: left !important;
  }
  .float-xxl-end {
    float: right !important;
  }
  .float-xxl-none {
    float: none !important;
  }
  .object-fit-xxl-contain {
    object-fit: contain !important;
  }
  .object-fit-xxl-cover {
    object-fit: cover !important;
  }
  .object-fit-xxl-fill {
    object-fit: fill !important;
  }
  .object-fit-xxl-scale {
    object-fit: scale-down !important;
  }
  .object-fit-xxl-none {
    object-fit: none !important;
  }
  .d-xxl-inline {
    display: inline !important;
  }
  .d-xxl-inline-block {
    display: inline-block !important;
  }
  .d-xxl-block {
    display: block !important;
  }
  .d-xxl-grid {
    display: grid !important;
  }
  .d-xxl-inline-grid {
    display: inline-grid !important;
  }
  .d-xxl-table {
    display: table !important;
  }
  .d-xxl-table-row {
    display: table-row !important;
  }
  .d-xxl-table-cell {
    display: table-cell !important;
  }
  .d-xxl-flex {
    display: flex !important;
  }
  .d-xxl-inline-flex {
    display: inline-flex !important;
  }
  .d-xxl-none {
    display: none !important;
  }
  .flex-xxl-fill {
    flex: 1 1 auto !important;
  }
  .flex-xxl-row {
    flex-direction: row !important;
  }
  .flex-xxl-column {
    flex-direction: column !important;
  }
  .flex-xxl-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-xxl-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-xxl-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-xxl-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-xxl-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-xxl-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-xxl-wrap {
    flex-wrap: wrap !important;
  }
  .flex-xxl-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-xxl-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-xxl-start {
    justify-content: flex-start !important;
  }
  .justify-content-xxl-end {
    justify-content: flex-end !important;
  }
  .justify-content-xxl-center {
    justify-content: center !important;
  }
  .justify-content-xxl-between {
    justify-content: space-between !important;
  }
  .justify-content-xxl-around {
    justify-content: space-around !important;
  }
  .justify-content-xxl-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-xxl-start {
    align-items: flex-start !important;
  }
  .align-items-xxl-end {
    align-items: flex-end !important;
  }
  .align-items-xxl-center {
    align-items: center !important;
  }
  .align-items-xxl-baseline {
    align-items: baseline !important;
  }
  .align-items-xxl-stretch {
    align-items: stretch !important;
  }
  .align-content-xxl-start {
    align-content: flex-start !important;
  }
  .align-content-xxl-end {
    align-content: flex-end !important;
  }
  .align-content-xxl-center {
    align-content: center !important;
  }
  .align-content-xxl-between {
    align-content: space-between !important;
  }
  .align-content-xxl-around {
    align-content: space-around !important;
  }
  .align-content-xxl-stretch {
    align-content: stretch !important;
  }
  .align-self-xxl-auto {
    align-self: auto !important;
  }
  .align-self-xxl-start {
    align-self: flex-start !important;
  }
  .align-self-xxl-end {
    align-self: flex-end !important;
  }
  .align-self-xxl-center {
    align-self: center !important;
  }
  .align-self-xxl-baseline {
    align-self: baseline !important;
  }
  .align-self-xxl-stretch {
    align-self: stretch !important;
  }
  .order-xxl-first {
    order: -1 !important;
  }
  .order-xxl-0 {
    order: 0 !important;
  }
  .order-xxl-1 {
    order: 1 !important;
  }
  .order-xxl-2 {
    order: 2 !important;
  }
  .order-xxl-3 {
    order: 3 !important;
  }
  .order-xxl-4 {
    order: 4 !important;
  }
  .order-xxl-5 {
    order: 5 !important;
  }
  .order-xxl-last {
    order: 6 !important;
  }
  .m-xxl-0 {
    margin: 0 !important;
  }
  .m-xxl-1 {
    margin: 0.25rem !important;
  }
  .m-xxl-2 {
    margin: 0.5rem !important;
  }
  .m-xxl-3 {
    margin: 1rem !important;
  }
  .m-xxl-4 {
    margin: 1.5rem !important;
  }
  .m-xxl-5 {
    margin: 3rem !important;
  }
  .m-xxl-auto {
    margin: auto !important;
  }
  .mx-xxl-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-xxl-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-xxl-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-xxl-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-xxl-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-xxl-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-xxl-auto {
    margin-right: auto !important;
    margin-left: auto !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: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-xxl-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .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: 3rem !important;
  }
  .mt-xxl-auto {
    margin-top: auto !important;
  }
  .me-xxl-0 {
    margin-right: 0 !important;
  }
  .me-xxl-1 {
    margin-right: 0.25rem !important;
  }
  .me-xxl-2 {
    margin-right: 0.5rem !important;
  }
  .me-xxl-3 {
    margin-right: 1rem !important;
  }
  .me-xxl-4 {
    margin-right: 1.5rem !important;
  }
  .me-xxl-5 {
    margin-right: 3rem !important;
  }
  .me-xxl-auto {
    margin-right: auto !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: 3rem !important;
  }
  .mb-xxl-auto {
    margin-bottom: auto !important;
  }
  .ms-xxl-0 {
    margin-left: 0 !important;
  }
  .ms-xxl-1 {
    margin-left: 0.25rem !important;
  }
  .ms-xxl-2 {
    margin-left: 0.5rem !important;
  }
  .ms-xxl-3 {
    margin-left: 1rem !important;
  }
  .ms-xxl-4 {
    margin-left: 1.5rem !important;
  }
  .ms-xxl-5 {
    margin-left: 3rem !important;
  }
  .ms-xxl-auto {
    margin-left: auto !important;
  }
  .p-xxl-0 {
    padding: 0 !important;
  }
  .p-xxl-1 {
    padding: 0.25rem !important;
  }
  .p-xxl-2 {
    padding: 0.5rem !important;
  }
  .p-xxl-3 {
    padding: 1rem !important;
  }
  .p-xxl-4 {
    padding: 1.5rem !important;
  }
  .p-xxl-5 {
    padding: 3rem !important;
  }
  .px-xxl-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-xxl-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-xxl-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-xxl-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-xxl-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-xxl-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !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: 3rem !important;
    padding-bottom: 3rem !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: 3rem !important;
  }
  .pe-xxl-0 {
    padding-right: 0 !important;
  }
  .pe-xxl-1 {
    padding-right: 0.25rem !important;
  }
  .pe-xxl-2 {
    padding-right: 0.5rem !important;
  }
  .pe-xxl-3 {
    padding-right: 1rem !important;
  }
  .pe-xxl-4 {
    padding-right: 1.5rem !important;
  }
  .pe-xxl-5 {
    padding-right: 3rem !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: 3rem !important;
  }
  .ps-xxl-0 {
    padding-left: 0 !important;
  }
  .ps-xxl-1 {
    padding-left: 0.25rem !important;
  }
  .ps-xxl-2 {
    padding-left: 0.5rem !important;
  }
  .ps-xxl-3 {
    padding-left: 1rem !important;
  }
  .ps-xxl-4 {
    padding-left: 1.5rem !important;
  }
  .ps-xxl-5 {
    padding-left: 3rem !important;
  }
  .gap-xxl-0 {
    gap: 0 !important;
  }
  .gap-xxl-1 {
    gap: 0.25rem !important;
  }
  .gap-xxl-2 {
    gap: 0.5rem !important;
  }
  .gap-xxl-3 {
    gap: 1rem !important;
  }
  .gap-xxl-4 {
    gap: 1.5rem !important;
  }
  .gap-xxl-5 {
    gap: 3rem !important;
  }
  .row-gap-xxl-0 {
    row-gap: 0 !important;
  }
  .row-gap-xxl-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-xxl-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-xxl-3 {
    row-gap: 1rem !important;
  }
  .row-gap-xxl-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-xxl-5 {
    row-gap: 3rem !important;
  }
  .column-gap-xxl-0 {
    column-gap: 0 !important;
  }
  .column-gap-xxl-1 {
    column-gap: 0.25rem !important;
  }
  .column-gap-xxl-2 {
    column-gap: 0.5rem !important;
  }
  .column-gap-xxl-3 {
    column-gap: 1rem !important;
  }
  .column-gap-xxl-4 {
    column-gap: 1.5rem !important;
  }
  .column-gap-xxl-5 {
    column-gap: 3rem !important;
  }
  .text-xxl-start {
    text-align: left !important;
  }
  .text-xxl-end {
    text-align: right !important;
  }
  .text-xxl-center {
    text-align: center !important;
  }
}
@media (min-width: 1200px) {
  .fs-1 {
    font-size: 2.5rem !important;
  }
  .fs-2 {
    font-size: 2rem !important;
  }
  .fs-3 {
    font-size: 1.75rem !important;
  }
  .fs-4 {
    font-size: 1.5rem !important;
  }
}
@media print {
  .d-print-inline {
    display: inline !important;
  }
  .d-print-inline-block {
    display: inline-block !important;
  }
  .d-print-block {
    display: block !important;
  }
  .d-print-grid {
    display: grid !important;
  }
  .d-print-inline-grid {
    display: inline-grid !important;
  }
  .d-print-table {
    display: table !important;
  }
  .d-print-table-row {
    display: table-row !important;
  }
  .d-print-table-cell {
    display: table-cell !important;
  }
  .d-print-flex {
    display: flex !important;
  }
  .d-print-inline-flex {
    display: inline-flex !important;
  }
  .d-print-none {
    display: none !important;
  }
}
/* 4) Our modern SCSS */
/* normalize-ish spot for global resets you want */
/* global type rules (h1–h6, p, links) */
/* custom grid helpers (if any) */
.btn {
  border: none;
}

/* =========================================================
   EmpowHERto — Baltimore Modal (Bootstrap shell, custom UI)
   ========================================================= */
/* Backdrop: darker + blur */
.modal-backdrop.show {
  background-color: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(2px);
}

/* Dialog sizing */
#baltimore-modal .modal-dialog {
  max-width: min(900px, 92vw);
}

/* Content grid replaces our old .card */
#baltimore-modal .modal-content {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  border: 0;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.22);
  container-type: inline-size; /* enables @container rules below */
}

/* Media pane */
#baltimore-modal .media {
  min-height: 260px;
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.45), rgba(0, 0, 0, 0.15)), url("/assets/img/events/EmpowHERto-event-announcement.jpg");
  background-size: cover;
  background-position: center 60%;
}

/* Content pane */
#baltimore-modal .content {
  --indigo: var(--clr-indigo, #2d1f4f);
  --pink: var(--clr-hot-pink, #ff2e88);
  --pad: 1.5rem;
  position: relative;
  padding: var(--pad) calc(var(--pad) + 0.25rem);
  background: radial-gradient(120% 140% at 110% -10%, rgba(255, 255, 255, 0) 30%, rgba(255, 255, 255, 0.35) 60%, rgba(255, 255, 255, 0.85) 90%), linear-gradient(160deg, color-mix(in oklab, var(--pink) 14%, white) 0%, color-mix(in oklab, var(--indigo) 14%, white) 100%);
  color: #1d1633;
}

/* Title / copy */
#baltimore-modal .title {
  margin: 0 0 0.5rem;
  font-size: clamp(1.35rem, 1rem + 1.4vw, 2rem);
  line-height: 1.15;
  color: var(--clr-indigo, #2d1f4f);
  text-wrap: balance;
}

#baltimore-modal .lead {
  margin: 0 0 0.5rem;
  font-size: clamp(1rem, 0.95rem + 0.6vw, 1.25rem);
  line-height: 1.5;
  color: #1b1b1b;
}

#baltimore-modal .smallprint {
  margin: 0.25rem 0 0;
  font-size: 0.85rem;
  opacity: 0.85;
  color: var(--clr-hot-pink);
}

/* Close button (use Bootstrap's .btn-close, but place it like ours) */
#baltimore-modal .btn-close {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  width: 40px;
  height: 40px;
  padding: 0;
  opacity: 0.85;
}

#baltimore-modal .btn-close:focus-visible {
  outline: 2px solid color-mix(in oklab, var(--clr-hot-pink, #ff2e88), black 10%);
  outline-offset: 2px;
}

/* Actions */
#baltimore-modal .actions {
  margin-top: 1rem;
}

#baltimore-modal .continue-btn.btn {
  border: none;
}

/* Responsive stack */
@container (max-width: 700px) {
  #baltimore-modal .modal-content {
    grid-template-columns: 1fr;
  }
  #baltimore-modal .media {
    min-height: 180px;
  }
}
@media (max-width: 720px) {
  #baltimore-modal .modal-content {
    grid-template-columns: 1fr;
  }
  #baltimore-modal .media {
    min-height: 180px;
  }
}
/* Motion prefs */
@media (prefers-reduced-motion: reduce) {
  #baltimore-modal .btn-close,
  #baltimore-modal .continue-btn {
    transition: none;
  }
}
/* small single-purpose classes (.u-visually-hidden etc.) */
/* 5) Legacy last (so it wins until migrated) */
/* ALL legacy styles concatenated via SCSS imports (inline at build) */
/* Keep the order identical to the old main.css so behavior doesn’t change. */
/* “Layers” comment left here just for reference; we’re not using CSS @layer */
:root {
  /* Brand Colors */
  --clr-hot-pink: #DF44A6;
  --clr-orange: #E89F56;
  --clr-lime-green: #CCF281;
  --clr-lilac: #BA92E8;
  --clr-indigo: #19162A;
  --clr-off-white: #EFEFEF;
  /* Text Color */
  --clr-text: #000;
  /* Soft (lighter + transparent) versions */
  --clr-soft-pink: hsla(320, 70%, 70%, 0.35); /* from hot pink */
  --clr-soft-orange: hsla(30, 74%, 75%, 0.35); /* from orange */
  --clr-soft-green: hsla(78, 80%, 85%, 0.35); /* from lime green */
  --clr-soft-lilac: hsla(270, 60%, 85%, 0.35); /* from lilac */
  --clr-soft-indigo: hsla(245, 25%, 25%, 0.25); /* subtle dark bg option */
  --primary: var(--clr-hot-pink);
  --secondary: var(--clr-lilac);
  --bg-color: #FFEFFA; /* subtle super light pinkish white */
  --global-nav-height: 60px;
  --padding-height: 20px;
  --spacer: 1rem;
}
@media (min-width: 768px) {
  :root :root {
    --global-nav-height: 90px; /* tablet and up */
  }
}
@media (min-width: 1024px) {
  :root :root {
    --global-nav-height: 100px; /* desktop */
  }
}
:root {
  /* ===== Typography tokens ===== */
  --font-sans: "FunnelDisplay", Arial, sans-serif;
  /* Weights (FunnelDisplay variable 'wght' axis) */
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-extrabold: 800;
  /* Line heights */
  --lh-tight: 1.1;
  --lh-snug: 1.25;
  --lh-normal: 1.45;
  --lh-relaxed: 1.6;
  /* Letter-spacing (tracking) */
  --track-tight: -0.015em;
  --track-normal: 0;
  --track-wide: 0.04em;
  --track-wider: 0.08em;
  /* Fluid type scale (clamp: mobile → desktop) */
  --step--2: clamp(0.75rem, 0.70rem + 0.25vw, 0.875rem); /* xs  (12→14px)  */
  --step--1: clamp(0.875rem, 0.82rem + 0.30vw, 1.00rem); /* sm  (14→16px)  */
  --step-0: clamp(1.00rem, 0.94rem + 0.40vw, 1.125rem); /* base(16→18px)  */
  --step-1: clamp(1.25rem, 1.14rem + 0.60vw, 1.50rem); /* lg  (20→24px)  */
  --step-2: clamp(1.50rem, 1.34rem + 0.90vw, 1.875rem); /* xl  (24→30px)  */
  --step-3: clamp(2.00rem, 1.80rem + 1.20vw, 2.50rem); /* 2xl (32→40px)  */
  --step-4: clamp(2.50rem, 2.10rem + 1.80vw, 3.25rem); /* 3xl (40→52px)  */
  --step-5: clamp(3.00rem, 2.60rem + 2.40vw, 4.00rem); /* 4xl (48→64px)  */
  /* Semantic aliases (use these across the app) */
  --text-xs: var(--step--2);
  --text-sm: var(--step--1);
  --text-base: var(--step-0);
  --text-lg: var(--step-1);
  --text-xl: var(--step-2);
  --display-sm: var(--step-3);
  --display-md: var(--step-4);
  --display-lg: var(--step-5);
  /* Heading & body colors */
  --heading-color: var(--clr-indigo);
  --body-color: var(--clr-text);
}

body {
  /* font-family: 'FunnelDisplay', Arial, sans-serif; */
  line-height: 1.6;
  background: var(--bg-color);
  color: var(--clr-text);
}

h1, .h1, h2, .h2, h3, .h3 {
  font-weight: 600;
}

a {
  color: var(--primary);
  text-decoration: none;
}

:root {
  /* Brand Colors */
  --clr-hot-pink: #DF44A6;
  --clr-orange: #E89F56;
  --clr-lime-green: #CCF281;
  --clr-dark-green: #1E9556;
  --clr-lilac: #BA92E8;
  --clr-dark-purple: #5F2DA9;
  --clr-indigo: #19162A;
  --clr-off-white: #EFEFEF;
  /* Text Color */
  --clr-text: #333;
  /* Soft (lighter + transparent) versions */
  --clr-soft-pink: hsla(320, 70%, 70%, 0.35); /* from hot pink */
  --clr-soft-orange: hsla(30, 74%, 75%, 0.35); /* from orange */
  --clr-soft-green: hsla(78, 80%, 85%, 0.35); /* from lime green */
  --clr-soft-lilac: hsla(270, 60%, 85%, 0.35); /* from lilac */
  --clr-soft-indigo: hsla(245, 25%, 25%, 0.25); /* subtle dark bg option */
  --primary: var(--clr-hot-pink);
  --secondary: var(--clr-lilac);
  --bg-color: #FFEFFA;
  --global-nav-height: 60px;
  --padding-height: 20px;
}
@media (min-width: 768px) {
  :root :root {
    --global-nav-height: 90px; /* tablet and up */
  }
}
@media (min-width: 1024px) {
  :root :root {
    --global-nav-height: 100px; /* desktop */
  }
}

body {
  /* TODO: start moving font stuff to type.css */
  /* font-family: 'FunnelDisplay', Arial, sans-serif; */
  line-height: 1.6;
  background: var(--bg-color);
  color: var(--clr-text);
  padding-top: var(--global-nav-height);
}

h1, .h1, h2, .h2, h3, .h3 {
  font-weight: 600;
}

a {
  color: var(--primary);
  text-decoration: none;
}

/* Make sure this loads after any resets */
:is(section, article, aside, nav) h1, :is(section, article, aside, nav) .h1 {
  font-size: clamp(3rem, 2.6rem + 2.4vw, 4rem);
}

/* Font-face blocks (your current ones) */
@font-face {
  font-family: "FunnelDisplay";
  src: url("../fonts/Funnel_Display/FunnelDisplay-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 1000;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "FunnelDisplay";
  src: url("../fonts/Funnel_Display/static/FunnelDisplay-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "FunnelDisplay";
  src: url("../fonts/Funnel_Display/static/FunnelDisplay-Medium.ttf") format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "FunnelDisplay";
  src: url("../fonts/Funnel_Display/static/FunnelDisplay-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "FunnelDisplay";
  src: url("../fonts/Funnel_Display/static/FunnelDisplay-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "FunnelDisplay";
  src: url("../fonts/Funnel_Display/static/FunnelDisplay-ExtraBold.ttf") format("truetype");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}
/* Base text */
html {
  font-size: 100%;
} /* 16px baseline */
body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--fw-regular);
  line-height: var(--lh-relaxed);
  color: var(--body-color);
  font-optical-sizing: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Headings — semantic defaults */
h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6 {
  color: var(--heading-color);
  font-weight: var(--fw-extrabold);
  line-height: var(--lh-tight);
  letter-spacing: var(--track-tight);
  margin: 0 0 0.5em;
  text-wrap: balance;
}

h1, .h1 {
  font-size: var(--display-lg);
}

h2, .h2 {
  font-size: var(--display-md);
}

h3, .h3 {
  font-size: var(--display-sm);
}

h4, .h4 {
  font-size: var(--text-xl);
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
}

h5, .h5 {
  font-size: var(--text-lg);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-snug);
}

h6, .h6 {
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-normal);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
}

/* Paragraphs & rhythm */
p {
  margin: 0 0 1em;
}

p.lead {
  font-size: var(--text-lg);
  line-height: var(--lh-normal);
  color: var(--clr-indigo);
}

small, .small {
  font-size: var(--text-sm);
  line-height: var(--lh-relaxed);
}

.caption {
  font-size: var(--text-xs);
  opacity: 0.75;
  line-height: var(--lh-relaxed);
}

/* Eyebrow / overline */
.eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--track-wider);
  text-transform: uppercase;
  color: var(--clr-indigo);
  margin-bottom: 0.5rem;
}

/* Utilities */
.measure {
  max-width: 65ch;
}

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

.nowrap {
  white-space: nowrap;
}

/* Buttons/links text (optional helper) */
.button-text {
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
}

/* default already uses --display-lg; keep it */
.hero .hero-text h1, .hero .hero-text .h1 {
  font-size: var(--display-lg, 4rem);
  line-height: var(--lh-tight, 1.1);
  letter-spacing: var(--track-tight, -0.015em);
  text-wrap: balance;
}

/* phones: use the next step down + slightly tighter layout */
@media (max-width: 640px) {
  .hero .hero-text h1, .hero .hero-text .h1 {
    font-size: var(--display-md, clamp(2.5rem, 2rem + 2.4vw, 3.25rem));
    line-height: 1.15;
    letter-spacing: -0.01em;
    margin: 0 0 0.5rem;
  }
}
/* very small phones: clamp again to avoid 3-line screams */
@media (max-width: 380px) {
  .hero .hero-text h1, .hero .hero-text .h1 {
    font-size: clamp(1.9rem, 6vw + 0.9rem, 2.4rem);
  }
}
header, footer {
  background-color: var(--clr-soft-pink);
  color: var(--clr-indigo);
  width: 100%;
  display: block;
}

footer, #section-stay-connected {
  background: var(--clr-orange);
  color: var(--clr-off-white);
}

footer {
  margin-top: auto;
  padding-block: 1rem;
}

.main-content {
  /* This now matches the fixed height of the global nav */
  /* padding-top: var(--global-nav-height); */
}

.container {
  width: min(90%, 1200px);
  margin-inline: auto;
}

/* .hero {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 80vh;
    background: var(--clr-soft-pink);
    color: white;
    text-align: center;
} */
#page-title {
  color: var(--clr-indigo);
  margin-top: 40px;
  margin-bottom: 60px;
}

#section-our-story {
  position: relative;
  display: block;
  margin: 0 auto;
  width: 100%;
  /* min-height: 400px; */
  padding: 4rem 0;
}
#section-our-story .story-title-bar {
  background: var(--clr-indigo);
  padding: 1rem 2rem;
  margin-bottom: 3rem;
  border-radius: 0 20px 20px 0;
  display: inline-block;
  margin-left: 0;
}
#section-our-story .story-title-bar h2, #section-our-story .story-title-bar .h2 {
  color: white;
  font-family: "FunnelDisplay", Arial, sans-serif;
  font-weight: 800;
  font-size: 2rem;
  text-transform: uppercase;
  margin: 0;
  text-align: center;
}

#section-our-story .left {
  display: inline-block;
  width: 60%;
  vertical-align: top;
  text-align: left;
}

#section-our-story .right {
  display: inline-block;
  width: 39%;
}

@media (max-width: 999px) {
  #section-our-story .left,
  #section-our-story .right {
    display: block;
    width: 100%;
  }
}
#section-our-story {
  background: var(--bg-color);
  background-size: cover;
  background-position: center;
  padding-block: 4rem;
}
#section-our-story .story-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}
@media (max-width: 768px) {
  #section-our-story .story-grid {
    grid-template-columns: 1fr;
    text-align: center;
  }
}
#section-our-story .story-text {
  max-width: 600px;
  color: black;
}
#section-our-story .story-text p {
  font-size: 1.1rem;
  font-weight: 300;
  line-height: 1.6;
  margin-bottom: 1.25rem;
  color: black;
}
#section-our-story .story-image {
  text-align: center;
}
#section-our-story .story-image .image-container {
  border: 2px solid var(--clr-lilac);
  border-radius: 20px;
  padding: 10px;
  display: inline-block;
}
#section-our-story .story-image .image-container img {
  width: 100%;
  max-width: 400px;
  border-radius: 15px;
  display: block;
}

#section-our-story,
#section-upcoming-events,
#section-our-impact,
#section-a21 {
  margin-block: 40px;
}
#section-our-story .heading-pill-wrapper,
#section-upcoming-events .heading-pill-wrapper,
#section-our-impact .heading-pill-wrapper,
#section-a21 .heading-pill-wrapper {
  background: var(--clr-indigo);
  color: var(--clr-off-white);
}

#section-a21 .a2i-header {
  color: var(--clr-dark-purple);
  max-width: 1150px;
  text-align: center;
  margin-inline: auto;
}
#section-a21 .a2i-description {
  max-width: 950px;
  text-align: center;
  margin-inline: auto;
}

#section-our-programs {
  margin-top: 40px;
  margin-bottom: 40px;
  isolation: isolate;
  position: relative;
  width: 100%;
  margin: 3rem auto;
}
#section-our-programs .heading-pill-wrapper {
  background: var(--clr-hot-pink);
}

#section-our-programs-listing .heading {
  padding: 20px 40px;
  font-size: 2.4em;
  font-weight: 600;
}

#section-our-programs-listing .content {
  border: 2px solid #CADE70;
  padding: 40px;
  padding-left: 10%;
  padding-right: 10%;
  background: #FFF9F9;
}

#section-our-programs-listing .content p {
  font-size: 1.6em;
}

#section-our-programs-listing .content img {
  margin-top: 30px;
  width: 100%;
}

#section-support-services {
  background: var(--clr-soft-pink);
  padding: 2rem 0;
}
#section-support-services .container {
  background: white;
  border-radius: 0.5rem;
  padding: 2rem 1rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  border: 1px solid rgba(0, 0, 0, 0.1);
  max-width: 1200px;
  margin: 0 auto;
}
#section-support-services .support-services-header {
  position: relative;
  text-align: center;
  margin-bottom: 3rem;
}
#section-support-services .support-services-header h2, #section-support-services .support-services-header .h2 {
  font-family: "FunnelDisplay", Arial, sans-serif;
  font-weight: 800;
  font-size: 3rem;
  color: var(--clr-indigo);
  margin-bottom: 0;
}
#section-support-services .support-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 2rem;
}
@media (max-width: 768px) {
  #section-support-services .support-services-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
}
@media (max-width: 1200px) {
  #section-support-services .container {
    margin: 0 1rem;
  }
}
#section-support-services .service-card {
  text-align: center;
}
#section-support-services .service-card img {
  width: 100%;
  height: 250px;
  object-fit: cover;
  border-radius: 8px;
  margin-bottom: 1rem;
}
#section-support-services .service-card h3, #section-support-services .service-card .h3 {
  font-family: "FunnelDisplay", Arial, sans-serif;
  font-weight: 700;
  font-size: 1.5rem;
  margin-bottom: 1rem;
  line-height: 1.2;
}
#section-support-services .service-card h3 .dark-text, #section-support-services .service-card .h3 .dark-text {
  color: var(--clr-indigo);
}
#section-support-services .service-card h3 .pink-text, #section-support-services .service-card .h3 .pink-text {
  color: var(--clr-hot-pink);
}
#section-support-services .service-card p {
  color: var(--clr-indigo);
  font-size: 0.9rem;
  line-height: 1.5;
  margin: 0;
}

/* ===== Special Thanks Section (no slider mechanics here) ===== */
#section-special-thanks {
  color: var(--clr-off-white);
  background: var(--clr-hot-pink);
  background: linear-gradient(90deg, var(--clr-hot-pink) 0%, var(--clr-orange) 100%);
  margin-top: 0px;
}
#section-special-thanks .container {
  margin: 3rem auto;
  text-align: center;
  padding-block: 2.75rem;
  color: var(--clr-off-white);
}
#section-special-thanks ul {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 2rem;
  position: relative;
  height: 80px;
  overflow: hidden;
  perspective: 1000px;
}
#section-special-thanks ul li {
  position: absolute;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
#section-special-thanks ul li:nth-child(1) {
  animation: slideFromTop 10s infinite;
}
#section-special-thanks ul li:nth-child(2) {
  animation: slideFromRight 10s infinite 2s;
}
#section-special-thanks ul li:nth-child(3) {
  animation: slideFromBottom 10s infinite 4s;
}
#section-special-thanks ul li:nth-child(4) {
  animation: slideFromLeft 10s infinite 6s;
}
#section-special-thanks ul li:nth-child(5) {
  animation: slideFromTopRight 10s infinite 8s;
}
#section-special-thanks ul li img {
  transition: transform 0.3s ease;
}
#section-special-thanks ul li:hover img {
  transform: scale(1.1);
}
#section-special-thanks h2, #section-special-thanks .h2 {
  text-align: center;
  color: var(--clr-off-white);
  font-size: var(--display-md);
  margin-bottom: calc(var(--spacer) / 2);
  animation: bounceTwice 2s ease-out;
}
#section-special-thanks .partners-subtitle {
  display: block;
  font-size: var(--display-sm);
  font-weight: 400;
  text-align: center;
  margin-bottom: auto;
  opacity: 1;
  color: white;
}

@keyframes slideFromTop {
  0%, 4% {
    opacity: 0;
    transform: translateY(-80px);
  }
  6%, 20% {
    opacity: 1;
    transform: translateY(0);
  }
  22%, 100% {
    opacity: 0;
    transform: translateY(80px);
  }
}
@keyframes slideFromRight {
  0%, 4% {
    opacity: 0;
    transform: translateX(80px);
  }
  6%, 20% {
    opacity: 1;
    transform: translateX(0);
  }
  22%, 100% {
    opacity: 0;
    transform: translateX(-80px);
  }
}
@keyframes slideFromBottom {
  0%, 4% {
    opacity: 0;
    transform: translateY(80px);
  }
  6%, 20% {
    opacity: 1;
    transform: translateY(0);
  }
  22%, 100% {
    opacity: 0;
    transform: translateY(-80px);
  }
}
@keyframes slideFromLeft {
  0%, 4% {
    opacity: 0;
    transform: translateX(-80px);
  }
  6%, 20% {
    opacity: 1;
    transform: translateX(0);
  }
  22%, 100% {
    opacity: 0;
    transform: translateX(80px);
  }
}
@keyframes slideFromTopRight {
  0%, 4% {
    opacity: 0;
    transform: translateY(-60px) translateX(60px);
  }
  6%, 20% {
    opacity: 1;
    transform: translateY(0) translateX(0);
  }
  22%, 100% {
    opacity: 0;
    transform: translateY(60px) translateX(-60px);
  }
}
@keyframes bounceTwice {
  0% {
    transform: translateY(-100px);
    opacity: 0;
  }
  20% {
    transform: translateY(0);
    opacity: 1;
  }
  30% {
    transform: translateY(-30px);
  }
  40% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-15px);
  }
  60% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}
#section-feedback {
  position: relative;
  text-align: center;
  background: var(--clr-soft-pink);
  padding-bottom: 5rem;
}
#section-feedback .section-hero img {
  width: 100%;
  height: 400px;
  display: block;
  object-fit: cover;
  object-position: center 25%;
}
#section-feedback .inquiry-form-container {
  position: relative;
  margin: -80px auto 0;
  z-index: 2;
  width: 90%;
  max-width: 700px;
}
#section-feedback .form-card {
  background: white;
  border-radius: 1.5rem;
  padding: 2.5rem;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
  text-align: left;
}
#section-feedback .form-card h2, #section-feedback .form-card .h2 {
  /* color: var(--clr-indigo); */
  text-align: center;
}
#section-feedback .form-card p {
  text-align: center;
  font-size: 1rem;
  color: var(--clr-text);
  margin-bottom: 2rem;
}
#section-feedback .form-card form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
#section-feedback .form-card form input,
#section-feedback .form-card form textarea {
  padding: 0.75rem;
  border: 1px solid #e0d5cc;
  border-radius: 6px;
  font-size: 1rem;
  background: #fceee9;
  resize: vertical;
}
#section-feedback .form-card form button {
  background: var(--clr-indigo);
  color: white;
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 6px;
  font-weight: bold;
  cursor: pointer;
  transition: background 0.3s ease;
}
#section-feedback .form-card form button:hover {
  background: var(--clr-lilac);
}

#section-upcoming-events {
  padding-top: 0 !important;
}
#section-upcoming-events .events-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 3rem;
  align-items: center;
}
#section-upcoming-events .event-image-container {
  text-align: center;
}
#section-upcoming-events .event-image-container img {
  width: 100%;
  max-width: 400px;
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}
#section-upcoming-events {
  /* .heading-pill {
      color: white !important;
  } */
}
#section-upcoming-events .event-content {
  color: var(--clr-text);
}
#section-upcoming-events .event-content h3, #section-upcoming-events .event-content .h3 {
  font-size: 2.5rem;
  font-weight: 800;
  margin-bottom: 1rem;
  color: var(--clr-text);
}
#section-upcoming-events .event-content p {
  font-size: 1.2rem;
  line-height: 1.6;
  color: var(--clr-text);
}

/* ===== Stay Connected (deduped) ===== */
#section-stay-connected {
  background: var(--clr-orange);
  color: var(--clr-off-white);
  text-align: center;
  padding: 3rem 1rem;
}
#section-stay-connected .container {
  max-width: 700px;
  margin: 0 auto;
}
#section-stay-connected .section-heading {
  font-size: var(--display-md);
  margin-bottom: calc(var(--spacer) * 3);
  color: inherit;
}
#section-stay-connected .social-icons {
  display: flex;
  justify-content: center;
  gap: 2rem;
  margin-bottom: calc(var(--spacer) * 3);
}
#section-stay-connected .social-icons a svg, #section-stay-connected .social-icons a img {
  width: 32px;
  height: 32px;
}
#section-stay-connected p a {
  color: white;
  text-decoration: underline;
}
#section-stay-connected p a:hover {
  text-decoration: none;
}

/* MV DEV */
/* Fort Lauderdale specific notes */
.fort-lauderdale-page #section-stay-connected {
  background: var(--clr-orange);
}

.fort-lauderdale-page footer {
  background: var(--clr-orange);
  margin: 0;
  padding: 0;
}

.fort-lauderdale-page footer * {
  margin-bottom: 0;
}

/* Toronto special thanks background variant */
.toronto-page #section-special-thanks {
  background: linear-gradient(90deg, #DF44A6 0%, #E89F57 100%);
}

body.landing-page {
  margin: 0;
  padding: 0;
  overflow: hidden;
}

#page-landing {
  height: 100vh;
  width: 100vw;
  min-height: 100vh;
  /* background-color: #FFFAF4; */
  background-image: url("../img/13.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-attachment: fixed;
  /* background: linear-gradient(to bottom, #3D1C65, #E846AD); */
  text-align: center;
  position: relative;
  overflow: hidden;
  /* MV DEV */
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  padding-top: 15vh;
}

/* #page-landing .image {
	width: 100%;
	height: 100vh;
	position: relative;
} */
/* #page-landing .image .bg {
	width: 100%;
	height: 100%;
} */
/* #page-landing .image .logo {
	position: absolute;
	top: 20vh;
	left: calc(50% - 250px);
	width: 500px;
} */
/* MV DEV */
#page-landing .image .logo {
  width: 400px;
  margin-bottom: 4rem;
  animation: logoBounce 1.2s ease-out;
  transition: filter 0.3s ease, transform 0.3s ease;
  pointer-events: none;
}

#page-landing .image .logo:hover {
  filter: drop-shadow(0 0 20px var(--clr-hot-pink)) drop-shadow(0 0 40px var(--clr-hot-pink));
  transform: scale(1.05);
  pointer-events: none;
}

@keyframes logoBounce {
  0% {
    opacity: 0;
    transform: translateY(-50px) scale(0.8);
  }
  50% {
    opacity: 1;
    transform: translateY(10px) scale(1.05);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
#page-landing .locations {
  width: 100%;
  text-align: center;
  animation: fadeInUp 0.8s ease-out 0.6s both;
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
#page-landing .locations p {
  text-transform: uppercase;
  color: var(--clr-text);
  font-weight: 300;
}

#page-landing p {
  color: var(--clr-text);
  font-size: 1.2em;
}

#page-landing a {
  color: var(--clr-text);
  text-decoration: none;
  margin: 10px;
  font-size: 1.5em;
  transition: color 0.3s ease;
}

#page-landing a:hover {
  color: var(--clr-lilac);
}

/* Responsive styles for smaller screens */
@media (max-width: 768px) {
  #page-landing .image .logo {
    width: 300px;
    margin-bottom: 3rem;
  }
}
@media (max-width: 480px) {
  #page-landing .image .logo {
    width: 200px;
    margin-bottom: 2rem;
  }
  #page-landing .locations p {
    font-size: 1em;
  }
  #page-landing a {
    font-size: 1.2em;
    margin: 8px;
  }
}
/* === Scroll-safety for landing page (desktop + mobile) === */
/* === prevent “broken” landing page on short/zoomed viewports === */
/* 1) Never hide page scroll on the landing page */
body.landing-page {
  overflow: auto !important; /* override earlier hidden */
}

/* 2) Let content exceed viewport when needed; avoid hard 100vh */
#page-landing {
  height: auto !important; /* drop fixed height */
  min-height: 100dvh; /* modern viewport unit */
  overflow-y: auto; /* allow scrolling if taller */
  -webkit-overflow-scrolling: touch;
  background-attachment: scroll; /* safer default across browsers */
}

/* 3) Re-enable fixed background only when there’s room (prevents scroll traps) */
@media (min-height: 800px) and (hover: hover) and (pointer: fine) {
  #page-landing {
    background-attachment: fixed;
  }
}
/* 4) Short/zoomed viewports: reduce top padding & logo size so buttons remain visible */
@media (max-height: 780px) {
  #page-landing {
    padding-top: 8vh; /* was 15vh */
  }
  #page-landing .image .logo {
    width: clamp(180px, 32vw, 320px);
    margin-bottom: 1.25rem;
  }
}
/* 5) Very short heights: ensure nothing forces 100vh back on */
@media (max-height: 600px) {
  html, body, #page-landing {
    height: auto !important;
  }
}
/* 6) iOS viewport quirk guard (optional but harmless on desktop) */
@supports (-webkit-touch-callout: none) {
  #page-landing {
    min-height: 100svh;
  }
}
#section-our-story {
  isolation: isolate;
  position: relative;
  width: 100%;
  margin: 3rem auto;
}

.our-story-section {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  padding: 4rem 2rem;
  overflow: hidden;
}

/* Content container */
.story-content {
  width: 70%;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  min-height: 500px;
  align-content: flex-start;
}

/* Left side - Text content */
.story-text {
  padding: 2rem;
}

.story-header {
  background: var(--clr-indigo);
  color: var(--clr-off-white);
  padding: 1rem 2rem;
  border-radius: 50px;
  display: inline-block;
  font-size: 1.5rem;
  font-weight: bold;
  letter-spacing: 1px;
  margin-bottom: 2rem;
  box-shadow: 0 8px 32px rgba(42, 42, 42, 0.3);
}

.story-paragraph {
  font-size: 1.1rem;
  line-height: 1.7;
  /* color: var(--clr-text); */
  margin-bottom: 1.5rem;
}

.story-paragraph:last-child {
  margin-bottom: 0;
}

/* Right side - Image */
.story-image-container {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 2rem;
}

.story-image {
  width: 100%;
  max-width: 300px;
  height: 400px;
  object-fit: cover;
  border-radius: 30px;
  /* box-shadow: 
  	0 20px 60px rgba(186, 133, 201, 0.3),
  	0 10px 30px rgba(186, 133, 201, 0.2),
  	0 5px 15px rgba(186, 133, 201, 0.1); */
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.story-image:hover {
  transform: translateY(-5px);
  /* box-shadow: 
  	0 25px 80px rgba(186, 133, 201, 0.4),
  	0 15px 40px rgba(186, 133, 201, 0.3),
  	0 8px 20px rgba(186, 133, 201, 0.2); */
}

/* Responsive design */
@media (max-width: 1024px) {
  .story-content {
    grid-template-columns: 1fr;
    gap: 3rem;
    text-align: center;
  }
  /* .gradient-background {
  	clip-path: polygon(
  		0% 15%, 
  		20% 0%, 
  		40% 5%, 
  		60% 0%, 
  		80% 8%, 
  		100% 25%, 
  		95% 50%, 
  		100% 75%, 
  		80% 92%, 
  		60% 100%, 
  		40% 95%, 
  		20% 100%, 
  		0% 85%
  	);
  } */
}
@media (max-width: 768px) {
  .our-story-section {
    padding: 2rem 1rem;
  }
  .story-header {
    font-size: 1.25rem;
    padding: 0.75rem 1.5rem;
  }
  .story-paragraph {
    font-size: 1rem;
  }
  .story-image {
    height: 250px;
    border-radius: 20px;
  }
}
/* Additional decorative elements */
.story-content::before {
  content: "";
  position: absolute;
  top: -50px;
  right: -50px;
  width: 100px;
  height: 100px;
  background: radial-gradient(circle, rgba(186, 133, 201, 0.1) 0%, transparent 70%);
  border-radius: 50%;
  z-index: 1;
}

.story-content::after {
  content: "";
  position: absolute;
  bottom: -30px;
  left: -30px;
  width: 60px;
  height: 60px;
  background: radial-gradient(circle, rgba(138, 201, 133, 0.1) 0%, transparent 70%);
  border-radius: 50%;
  z-index: 1;
}

/* =====================  BASE  ===================== */
/* Host that can contain absolute-positioned decor */
.decor {
  position: relative;
  isolation: isolate; /* keeps z-index of children contained */
}

/* Content by default sits above decor */
.decor > * {
  position: relative;
  z-index: 1;
}

/* All decor primitives live *under* content */
.decor > .decor-blob,
.decor > .decor-dots,
.decor > .decor-corner,
.decor > .decor-corner-pair {
  position: absolute;
  z-index: 0;
  pointer-events: none;
}

/* -------- Position anchors -------- */
.decor-top-right {
  top: clamp(10px, 3vw, 28px);
  right: clamp(12px, 4vw, 48px);
}

.decor-top-left {
  top: clamp(10px, 3vw, 28px);
  left: clamp(12px, 4vw, 48px);
}

.decor-mid-right {
  top: 50%;
  right: clamp(12px, 4vw, 48px);
  transform: translateY(-50%);
}

.decor-bottom-left {
  bottom: clamp(12px, 4vw, 48px);
  left: clamp(12px, 5vw, 64px);
}

.decor-bottom-right {
  bottom: clamp(12px, 4vw, 48px);
  right: clamp(12px, 5vw, 64px);
}

.decor-center-left {
  top: 50%;
  left: clamp(12px, 5vw, 64px);
  transform: translateY(-50%) rotate(var(--decor-rotate, 0deg));
}

.decor-center-right {
  top: 50%;
  right: clamp(12px, 5vw, 64px);
  transform: translateY(-50%) rotate(var(--decor-rotate, 0deg));
}

/* -------- Color helpers -------- */
.decor-color-lime {
  --dec-color: var(--clr-lime-green);
}

.decor-color-pink {
  --dec-color: var(--clr-hot-pink);
}

.decor-color-soft-pink {
  --dec-color: var(--clr-soft-pink);
}

.decor-color-soft-green {
  --dec-color: var(--clr-soft-green);
}

.decor-color-soft-lilac {
  --dec-color: var(--clr-soft-lilac);
}

.decor-color-soft-indigo {
  --dec-color: var(--clr-soft-indigo);
}

/* -------- Long rounded bar (kept for reuse) -------- */
.decor-bar {
  width: clamp(180px, 30vw, 360px);
  height: clamp(16px, 3vw, 28px);
  background: var(--dec-color, var(--clr-lime-green));
  border-radius: 9999px;
  filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.03));
}

/* -------- Blob rings -------- */
.decor-blob {
  --decor-size: clamp(220px, 35vw, 563px);
  width: var(--decor-size);
  height: var(--decor-size);
  border-radius: var(--decor-radius, 50%);
  /* ring geometry */
  --ring-base: 58%;
  --ring-w2: 6%;
  --ring-gap: 4%;
  --ring-w1: 6%;
  --ring-alpha-outer: .26;
  --ring-alpha-inner: .18;
  --ring-color-outer: rgba(147,120,175,.26);
  --ring-color-inner: rgba(147,120,175,.18);
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
  background-image: radial-gradient(circle at 50% 50%, transparent 0 var(--ring-base), var(--ring-color-inner) var(--ring-base) calc(var(--ring-base) + var(--ring-w2)), transparent calc(var(--ring-base) + var(--ring-w2)) calc(var(--ring-base) + var(--ring-w2) + var(--ring-gap)), var(--ring-color-outer) calc(var(--ring-base) + var(--ring-w2) + var(--ring-gap)) calc(var(--ring-base) + var(--ring-w2) + var(--ring-gap) + var(--ring-w1)), transparent calc(var(--ring-base) + var(--ring-w2) + var(--ring-gap) + var(--ring-w1)) 100%);
  filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.02));
}

@supports (color: rgb(from #000 r g b/1)) {
  .decor-blob {
    --ring-color-outer: rgb(from var(--dec-color, #9378AF) r g b / var(--ring-alpha-outer));
    --ring-color-inner: rgb(from var(--dec-color, #9378AF) r g b / var(--ring-alpha-inner));
  }
}
/* -------- Single quarter corner -------- */
.decor-corner {
  --size: clamp(34px, 8vw, 72px);
  width: var(--size);
  height: var(--size);
  --corner-alpha: 1;
  --corner-source: var(--corner-color, var(--dec-color, var(--clr-soft-pink)));
  background-color: var(--corner-source);
  --ax: 0%;
  --ay: 0%;
  -webkit-mask: radial-gradient(100% 100% at var(--ax) var(--ay), #000 99.5%, rgba(0, 0, 0, 0) 100%);
  mask: radial-gradient(100% 100% at var(--ax) var(--ay), #000 99.5%, rgba(0, 0, 0, 0) 100%);
  transform: rotate(var(--corner-rotate, 0deg));
}

@supports (color: rgb(from #000 r g b/1)) {
  .decor-corner {
    background-color: rgb(from var(--corner-source) r g b/var(--corner-alpha));
  }
}
.decor-corner.tl {
  top: 0;
  left: 0;
  --ax: 0%;
  --ay: 0%;
}

.decor-corner.tr {
  top: 0;
  right: 0;
  --ax: 100%;
  --ay: 0%;
}

.decor-corner.bl {
  bottom: 0;
  left: 0;
  --ax: 0%;
  --ay: 100%;
}

.decor-corner.br {
  bottom: 0;
  right: 0;
  --ax: 100%;
  --ay: 100%;
}

/* -------- Corner pair (two stacked quarters) -------- */
.decor-corner-pair {
  --pair-size: clamp(44px, 10vw, 96px);
  --pair-gap: clamp(10px, 1.6vw, 18px);
  --pair-alpha: 1;
  --pair-source: var(--pair-color, var(--dec-color, var(--clr-hot-pink)));
  width: var(--pair-size);
  height: calc(var(--pair-size) * 2 + var(--pair-gap));
}

.decor-corner-pair.left {
  left: 0;
  --ax-top: 0%;
  --ay-top: 0%;
  --ax-bot: 0%;
  --ay-bot: 100%;
}

.decor-corner-pair.right {
  right: 0;
  --ax-top: 100%;
  --ay-top: 0%;
  --ax-bot: 100%;
  --ay-bot: 100%;
}

.decor-corner-pair::before,
.decor-corner-pair::after {
  content: "";
  position: absolute;
  left: 0;
  width: var(--pair-size);
  height: var(--pair-size);
  background-color: var(--pair-source);
}

@supports (color: rgb(from #000 r g b/1)) {
  .decor-corner-pair::before,
  .decor-corner-pair::after {
    background-color: rgb(from var(--pair-source) r g b/var(--pair-alpha));
  }
}
.decor-corner-pair::before {
  top: 0;
  -webkit-mask: radial-gradient(100% 100% at var(--ax-top) var(--ay-top), #000 99.5%, rgba(0, 0, 0, 0) 100%);
  mask: radial-gradient(100% 100% at var(--ax-top) var(--ay-top), #000 99.5%, rgba(0, 0, 0, 0) 100%);
}

.decor-corner-pair::after {
  top: calc(var(--pair-size) + var(--pair-gap)); /* keep the gap */
  -webkit-mask: radial-gradient(100% 100% at var(--ax-bot) var(--ay-bot), #000 99.5%, rgba(0, 0, 0, 0) 100%);
  mask: radial-gradient(100% 100% at var(--ax-bot) var(--ay-bot), #000 99.5%, rgba(0, 0, 0, 0) 100%);
}

/* make bottom quarter same orientation as top */
.decor-corner-pair.pair-same::after {
  -webkit-mask: radial-gradient(100% 100% at var(--ax-top) var(--ay-top), #000 99.5%, rgba(0, 0, 0, 0) 100%);
  mask: radial-gradient(100% 100% at var(--ax-top) var(--ay-top), #000 99.5%, rgba(0, 0, 0, 0) 100%);
}

/* -------- Dot grid (pattern lives on ::before when stepped) -------- */
.decor-dots {
  --dot: clamp(6px, 1.2vw, 10px);
  --gap: clamp(12px, 2vw, 20px);
  --dot-alpha: .65;
  --dot-source: var(--dot-color, var(--dec-color, var(--clr-soft-green)));
  --dots-cols: 6;
  --dots-rows: 4;
  --dots-tx: 0;
  --dots-ty: 0;
  width: calc(var(--gap) * var(--dots-cols));
  height: calc(var(--gap) * var(--dots-rows));
  color: var(--dot-source);
  transform: translate(var(--dots-tx), var(--dots-ty)) rotate(var(--dots-rotate, 0deg));
}

@supports (color: rgb(from #000 r g b/1)) {
  .decor-dots {
    color: rgb(from var(--dot-source) r g b/var(--dot-alpha));
  }
}
/* default (rectangular) grid uses background on the host */
.decor-dots {
  background: radial-gradient(currentColor var(--dot), transparent var(--dot)) 0 0/var(--gap) var(--gap);
}

/* stepped left edge variant puts the pattern on ::before and clips it */
.dots-stairs-l-5 {
  background: radial-gradient(currentColor var(--dot), transparent var(--dot)) 0 0/var(--gap) var(--gap);
}

.dots-stairs-l-5::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(currentColor var(--dot), transparent var(--dot)) var(--gap) var(--gap)/var(--gap) var(--gap);
  clip-path: polygon(0% 12.5%, 100% 12.5%, 100% 25%, 0% 25%, 0% 37.5%, 100% 37.5%, 100% 50%, 0% 50%, 0% 62.5%, 100% 62.5%, 100% 75%, 0% 75%, 0% 87.5%, 100% 87.5%, 100% 100%, 0% 100%);
}

/* ===== 3b) Exact SVG motif ===== */
/* Two modes:
   - .image → uses the SVG exactly as designed (color comes from the file)
   - .mask  → tints the SVG with CSS (requires a white/transparent SVG)
*/
.decor-dots-svg {
  position: absolute;
  z-index: 0;
  pointer-events: none;
  /* default geometry */
  --svg-w: clamp(120px, 20vw, 240px);
  width: var(--svg-w);
  aspect-ratio: var(--svg-aspect, 379/509); /* your file's viewBox */
  /* optional rotation (composes with position helpers) */
  transform: rotate(var(--svg-rotate, 0deg));
  /* optional opacity */
  opacity: var(--svg-opacity, 1);
}

/* --- Image mode (exact colors from the file) --- */
.decor-dots-svg.image {
  background: center/contain no-repeat url("../graphics/empowherto-dots.svg");
}

/* --- Mask mode (tint with any color) --- */
.decor-dots-svg.mask {
  background: var(--dec-color, var(--clr-soft-green));
  -webkit-mask: url("/assets/graphics/empowherto-dots-white.svg") center/contain no-repeat;
  mask: url("/assets/graphics/empowherto-dots-white.svg") center/contain no-repeat;
}

/* =====================  OVERRIDES (placements)  ===================== */
.decor-corner-pair {
  --pair-alpha: .35;
}

.decor-corner-pair::before, .decor-corner-pair::after {
  --pair-alpha: .35;
}

/* Our Impact — bigger, softer rings on left */
#section-our-impact .decor-blob.decor-center-left {
  --decor-size: clamp(320px, 48vw, 720px);
  --ring-base: 62%;
  --ring-alpha-outer: .20;
  --ring-alpha-inner: .14;
}

/* Our Impact — top-right stepped lime dots (two layers; second is nudged) */
#section-our-impact .decor-dots.decor-top-right {
  top: clamp(20px, 6vw, 88px);
  right: clamp(20px, 6vw, 88px);
  --dot: clamp(8px, 1.2vw, 10px);
  --gap: clamp(16px, 2vw, 20px);
  --dot-alpha: .9;
}

/* Our Impact — right-side pink corner pair */
#section-our-impact .decor-corner-pair.right {
  top: 50%;
  right: 0px;
  transform: translateY(-50%); /* rotation handled by masks */
  --pair-size: clamp(44px, 9vw, 96px);
  --pair-gap: clamp(12px, 2vw, 20px);
  --pair-alpha: .9;
}

#section-our-impact .decor-dots-svg.decor-top-right {
  top: clamp(20px, 6vw, 88px);
  right: clamp(20px, 6vw, 88px);
}

/* =====================  UTILITIES  ===================== */
/* sizes for corner pairs */
.corner-size-sm {
  --pair-size: clamp(36px, 8vw, 80px);
}

.corner-size-md {
  --pair-size: clamp(44px, 9vw, 96px);
}

.corner-size-lg {
  --pair-size: clamp(48px, 9vw, 112px);
}

/* gaps for corner pairs */
.corner-gap-sm {
  --pair-gap: clamp(8px, 1.5vw, 16px);
}

.corner-gap-md {
  --pair-gap: clamp(12px, 2vw, 24px);
}

.corner-gap-lg {
  --pair-gap: clamp(16px, 2.5vw, 28px);
}

/* optional opacity helpers */
.corner-alpha-100 {
  --pair-alpha: 1;
  --pair-alpha:1;
}

.corner-alpha-90 {
  --corner-alpha:.9;
  --pair-alpha:.9;
}

.corner-alpha-80 {
  --pair-alpha: .8;
  --pair-alpha:.8;
}

.corner-alpha-70 {
  --corner-alpha:.7;
  --pair-alpha:.7;
}

.corner-alpha-60 {
  --pair-alpha: .6;
  --pair-alpha:.6;
}

.corner-alpha-50 {
  --corner-alpha:.5;
  --pair-alpha:.5;
}

.corner-alpha-35 {
  --corner-alpha:.35;
  --pair-alpha:.35;
}

/* small offset for a second corner pair */
.corner-nudge-up-right {
  transform: translate(calc(var(--pair-gap) * 0.8), calc(var(--pair-gap) * -1));
}

/* dot grid footprints */
.dots-4x3 {
  --dots-cols: 4;
  --dots-rows: 3;
}

.dots-6x4 {
  --dots-cols: 6;
  --dots-rows: 4;
}

.dots-8x5 {
  --dots-cols: 8;
  --dots-rows: 5;
}

.dots-6x6 {
  --dots-cols: 6;
  --dots-rows: 6;
}

.dots-7x6 {
  --dots-cols: 7;
  --dots-rows: 6;
}

/* one-column inset amounts for left bite */
.dots-inset-1col-7 {
  --dots-inset: 14.285%;
} /* 1/7 */
.dots-inset-1col-6 {
  --dots-inset: 16.667%;
} /* 1/6 */
/* layer offsets for a second grid */
.dots-nudge-up-left {
  --dots-tx: calc(var(--gap) * -1);
  --dots-ty: calc(var(--gap) * -1);
}

.dots-nudge-left {
  --dots-tx: calc(var(--gap) * -1);
}

.dots-nudge-up {
  --dots-ty: calc(var(--gap) * -1);
}

/* ---- sizes ---- */
.dots-svg-xs {
  --svg-w: clamp(80px, 12vw, 120px);
}

.dots-svg-sm {
  --svg-w: clamp(100px, 16vw, 180px);
}

.dots-svg-md {
  --svg-w: clamp(120px, 20vw, 240px);
}

.dots-svg-lg {
  --svg-w: clamp(160px, 24vw, 300px);
}

.dots-svg-xl {
  --svg-w: clamp(200px, 28vw, 360px);
}

/* ---- rotation ---- */
.dots-svg-rot-15 {
  --svg-rotate: 15deg;
}

.dots-svg-rot-30 {
  --svg-rotate: 30deg;
}

.dots-svg-rot-45 {
  --svg-rotate: 45deg;
}

.dots-svg-rot--15 {
  --svg-rotate: -15deg;
}

.dots-svg-rot--30 {
  --svg-rotate: -30deg;
}

/* ---- opacity ---- */
.dots-svg-op-50 {
  --svg-opacity: .5;
}

.dots-svg-op-70 {
  --svg-opacity: .7;
}

.dots-svg-op-80 {
  --svg-opacity: .8;
}

.dots-svg-op-90 {
  --svg-opacity: .9;
}

/* quick debug */
.debug-outline {
  outline: 1px dashed hotpink;
}

/* helper for the honeypot label */
.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

#section-feedback .form-card h2, #section-feedback .form-card .h2 {
  margin-bottom: 0.5rem;
}
#section-feedback .form-card p {
  margin-bottom: 2rem;
  color: var(--clr-indigo);
  opacity: 0.9;
}
#section-feedback .form-card form {
  gap: 1.25rem;
}
#section-feedback .form-card form .form-row.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
@media (max-width: 500px) {
  #section-feedback .form-card form .form-row.two-col {
    grid-template-columns: 1fr;
  }
}
#section-feedback .form-card form .field {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
#section-feedback .form-card form label {
  font-weight: 700;
  font-size: 1rem;
  color: var(--clr-indigo);
  letter-spacing: 0.01em;
}
#section-feedback .form-card form .req {
  margin-inline-start: 0.25rem;
  color: var(--clr-hot-pink);
}
#section-feedback .form-card form input,
#section-feedback .form-card form textarea {
  padding: 0.85rem;
  border: 2px solid #efb788; /* Figma-like warm outline */
  border-radius: 10px;
  font-size: 1rem;
  background: #fbe9e2; /* soft peach fill */
  color: var(--clr-text);
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
#section-feedback .form-card form input::placeholder,
#section-feedback .form-card form textarea::placeholder {
  color: rgba(51, 51, 51, 0.55);
}
#section-feedback .form-card form input:focus,
#section-feedback .form-card form textarea:focus {
  border-color: var(--clr-indigo);
  box-shadow: 0 0 0 3px rgba(25, 22, 42, 0.12);
}
#section-feedback .form-card form {
  /* invalid/valid state styling */
}
#section-feedback .form-card form .field.invalid input,
#section-feedback .form-card form .field.invalid textarea {
  border-color: var(--clr-hot-pink);
}
#section-feedback .form-card form .field.valid input,
#section-feedback .form-card form .field.valid textarea {
  border-color: #9ad18b; /* subtle green edge */
}
#section-feedback .form-card form .error-text {
  min-height: 1.1em;
  font-size: 0.875rem;
  color: var(--clr-hot-pink);
}
#section-feedback .form-card form .form-actions {
  display: flex;
  justify-content: center;
  margin-top: 0.5rem;
}
#section-feedback .form-card form button {
  background: var(--clr-indigo);
  color: #fff;
  padding: 0.9rem 2.25rem;
  border: none;
  border-radius: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  cursor: pointer;
  transition: transform 0.06s ease, background 0.2s ease;
}
#section-feedback .form-card form button:hover {
  background: var(--clr-lilac);
}
#section-feedback .form-card form button:active {
  transform: translateY(1px);
}

/* ===================== */
/* Inquire form fallbacks */
/* ===================== */
/* If the partial is used outside #section-feedback, reserve space for errors */
.form-inquire .error-text {
  min-height: 1.1em;
  font-size: 0.875rem;
  color: var(--clr-hot-pink);
}

/* Mirror your valid/invalid borders for usage outside the section scope */
.form-inquire .field.invalid input,
.form-inquire .field.invalid textarea {
  border-color: var(--clr-hot-pink);
}

.form-inquire .field.valid input,
.form-inquire .field.valid textarea {
  border-color: #9ad18b; /* subtle green edge */
}

/* Ensure the two-column layout works even if the form isn't inside #section-feedback */
.form-inquire .form-row.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

@media (max-width: 500px) {
  .form-inquire .form-row.two-col {
    grid-template-columns: 1fr;
  }
}
/* ===== Global nav ===== */
#global-nav {
  color: var(--clr-hot-pink);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--global-nav-height);
  background-color: color-mix(in srgb, currentColor 80%, transparent);
  padding: 0 2rem;
  margin: 0 auto;
  z-index: 1000;
  display: flex;
  align-items: center;
}

/* keep container flex for spacing */
#global-nav .container {
  width: min(90%, 1200px);
  margin: 0 auto;
  height: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-block: calc(var(--padding-height) / 2);
  gap: 0.75rem;
}

/* ===== Brand / Logomark: never shrink away ===== */
#global-nav #logomark {
  height: clamp(28px, 2.2vh + 14px, 40px); /* ~28→40 */
  min-height: 28px; /* hard floor (prevents vanish) */
  width: auto;
  flex: 0 0 auto; /* do not flex-shrink */
  display: block;
  object-fit: contain;
}

/* ===== Controls ===== */
#global-nav .menu-controls {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex: 0 1 auto;
  min-width: 0; /* allow pills to truncate instead of pushing logo */
}

#global-nav .menu-toggle {
  cursor: pointer;
  background: none;
  border: none;
  padding: 10px;
  display: flex;
  align-items: center;
  flex: 0 0 auto;
}

#global-nav .menu-toggle img {
  height: 25px;
  width: 25px;
}

/* ===== Compact pills on narrow screens, prefer truncation ===== */
@media (max-width: 420px) {
  #global-nav {
    padding: 0 0.75rem;
  }
  #global-nav .container {
    gap: 0.5rem;
  }
  #global-nav .menu-controls .current-location-btn,
  #global-nav .menu-controls .btn,
  #global-nav .menu-controls .pill {
    padding: 0.4rem 0.6rem;
    font-size: var(--text-sm);
    line-height: 1.1;
    border-radius: 999px;
  }
  /* clip location text before touching the logo */
  #global-nav .menu-controls .current-location-btn .location-name {
    max-width: 8.5rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: inline-block;
    vertical-align: bottom;
  }
}
/* ===== Open menu panel (unchanged) ===== */
#global-nav-menu {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  background: var(--clr-off-white);
  transition: transform 0.4s ease, opacity 0.4s ease;
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
  z-index: 900;
  padding: 2rem auto;
  overflow: hidden;
}

#global-nav-menu.is-open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

#global-nav-menu .nav-header {
  --global-nav-height: 45px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 25px;
  background: var(--clr-off-white);
  border-bottom: 1px solid var(--clr-off-white);
  min-height: var(--global-nav-height);
}

#global-nav-menu .nav-header #logomark-menu {
  height: 40px;
}

#global-nav-menu .nav-header .menu-header-controls {
  display: flex;
  align-items: center;
}

#global-nav-menu .nav-header .menu-header-controls .close-btn {
  background: none;
  border: none;
  cursor: pointer;
  padding: 5px;
}

#global-nav-menu .nav-header .menu-header-controls .close-btn img {
  width: 30px;
  height: 30px;
}

/* ===== Decorative layer (behind links) ===== */
#global-nav-menu .menu-decor {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

#global-nav-menu .menu-decor .decor-left {
  position: absolute;
  left: 0;
  bottom: 0;
  width: clamp(140px, 18vw, 260px);
  height: clamp(140px, 18vw, 260px);
  background: url("/assets/graphics/petal-bottom-left.svg") no-repeat left bottom/contain;
  opacity: 0.95;
  image-rendering: auto;
  will-change: transform;
}

#global-nav-menu .menu-decor .decor-right {
  position: absolute;
  right: clamp(-120px, -8vw, -40px);
  bottom: clamp(-120px, -10vh, -40px);
  width: clamp(420px, 45vw, 820px);
  height: clamp(300px, 36vw, 600px);
  background: url("/assets/graphics/dots-6x4-lime.svg") no-repeat 22% 58%/clamp(200px, 22vw, 360px) auto, url("/assets/graphics/arcs-lavender.svg") no-repeat right bottom/contain;
  opacity: 0.9;
  image-rendering: auto;
  will-change: transform;
}

/* ===== Menu items grid ===== */
#global-nav-menu .nav-links {
  position: relative;
  z-index: 1;
  background: transparent;
  display: grid;
  grid-template-columns: repeat(4, minmax(180px, 1fr));
  justify-content: center;
  align-content: center;
  place-items: center;
  column-gap: clamp(2rem, 6vw, 6rem);
  row-gap: clamp(2rem, 6vw, 6rem);
  flex: 1;
  padding-block: 0;
  min-height: calc(100dvh - var(--menu-header-height, 64px));
}

#global-nav-menu .nav-links > .nav-item {
  background: transparent;
  border: 0 !important;
  box-shadow: none;
  width: 100%;
  min-height: 200px;
  padding: 2rem 1.75rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-decoration: none;
  color: var(--clr-text);
  transition: transform 0.25s ease, background 0.25s ease, opacity 0.25s ease;
}

#global-nav-menu .nav-links > .nav-item:hover {
  opacity: 1;
  background: color-mix(in srgb, var(--clr-soft-pink) 15%, transparent);
  border-radius: 16px;
  transform: translateY(-4px);
}

#global-nav-menu .nav-links > .nav-item .nav-icon-wrapper {
  margin: 0 0 1rem 0;
  display: grid;
  place-items: center;
  min-height: clamp(92px, 10vw, 128px);
}

#global-nav-menu .nav-links > .nav-item .nav-icon-wrapper .nav-icon {
  height: clamp(92px, 10vw, 128px);
  width: auto;
  display: block;
}

#global-nav-menu .nav-links > .nav-item .nav-label {
  font-weight: 800;
  letter-spacing: 0.02em;
  text-transform: none;
  font-size: clamp(1.05rem, 1.8vw, 1.75rem);
  line-height: 1.2;
  text-align: center;
}

/* toggles */
.menu-toggle.close-btn {
  display: none;
}

.menu-toggle[hidden] {
  display: none !important;
}

/* ===== Responsive ===== */
@media (max-width: 1024px) {
  #global-nav-menu .nav-links {
    grid-template-columns: repeat(2, minmax(160px, 1fr));
  }
}
@media (max-width: 520px) {
  #global-nav-menu .nav-links {
    grid-template-columns: 1fr 1fr;
    column-gap: 2rem;
    row-gap: 2.5rem;
  }
  #global-nav-menu .nav-links > .nav-item .nav-icon-wrapper {
    min-height: clamp(72px, 22vw, 92px);
  }
  #global-nav-menu .nav-links > .nav-item .nav-icon-wrapper .nav-icon {
    height: clamp(72px, 22vw, 92px);
  }
  #global-nav-menu .nav-links > .nav-item .nav-label {
    font-size: clamp(0.95rem, 3.8vw, 1.1rem);
  }
  #global-nav-menu .menu-decor .decor-left {
    opacity: 0.6;
  }
  #global-nav-menu .menu-decor .decor-right {
    opacity: 0.65;
  }
}
/* utility */
.sr-only {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 1px 1px);
  white-space: nowrap;
  border: 0;
}

/* ===== Location switcher (unchanged) ===== */
.location-switcher {
  position: relative;
  display: inline-flex;
  align-items: center;
  z-index: 1000;
}

.current-location-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 10px 16px;
  border-radius: 18px;
  cursor: pointer;
  color: var(--clr-off-white);
  background: color-mix(in srgb, var(--primary) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--clr-off-white) 35%, transparent);
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease;
  box-shadow: 0 6px 20px color-mix(in srgb, var(--primary) 18%, transparent);
}

.current-location-btn:hover,
.current-location-btn:focus-visible {
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--primary) 26%, transparent);
  border-color: color-mix(in srgb, var(--clr-off-white) 55%, transparent);
  outline: none;
}

.location-icon {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

.dropdown-arrow {
  width: 12px;
  height: 12px;
  fill: currentColor;
  transition: transform 0.25s ease;
}

.location-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 280px;
  background: var(--bg-color);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 12px 32px color-mix(in srgb, var(--clr-indigo) 24%, transparent);
  transform: translateY(-10px);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.2s ease, opacity 0.2s ease;
  border: 1px solid color-mix(in srgb, var(--clr-indigo) 12%, transparent);
}

.location-switcher[aria-expanded=true] .location-dropdown,
.location-switcher.is-open .location-dropdown {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.location-switcher[aria-expanded=true] .dropdown-arrow,
.location-switcher.is-open .dropdown-arrow {
  transform: rotate(180deg);
}

.dropdown-header {
  padding: 14px 16px;
  font-weight: 800;
  font-size: 0.9rem;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: #fff;
  background: var(--clr-indigo);
}

.location-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  color: var(--clr-text);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--clr-indigo) 8%, transparent);
  transition: background 0.15s ease, transform 0.15s ease;
}

.location-option:last-child {
  border-bottom: 0;
}

.location-option:hover,
.location-option:focus-visible {
  background: var(--clr-soft-pink);
  transform: translateX(4px);
  outline: none;
}

.location-option.current {
  background: color-mix(in srgb, var(--primary) 12%, transparent);
  color: var(--primary);
  font-weight: 700;
}

.location-option.current::after {
  content: "✓";
  margin-left: auto;
  font-weight: 800;
  color: var(--primary);
}

.flag-icon {
  width: 24px;
  height: 18px;
  border-radius: 3px;
  border: 1px solid color-mix(in srgb, var(--clr-indigo) 12%, transparent);
  background: linear-gradient(to right, #fff 100%, #fff 0);
}

.flag-us {
  background: linear-gradient(to bottom, #b22234 10%, #fff 10%, #fff 20%, #b22234 20%, #b22234 30%, #fff 30%, #fff 40%, #b22234 40%, #b22234 50%, #fff 50%, #fff 60%, #b22234 60%, #b22234 70%, #fff 70%, #fff 80%, #b22234 80%, #b22234 90%, #fff 90%, #fff 100%), linear-gradient(to right, #3c3b6e 0 40%, transparent 40% 100%);
}

.location-details {
  display: flex;
  flex-direction: column;
}

.location-name {
  font-weight: 700;
  line-height: 1.1;
}

.location-country {
  font-size: 0.85rem;
  opacity: 0.7;
}

/* === Fix: keep location dropdown on-screen (mobile) === */
@media (max-width: 640px) {
  /* ensure nothing clips the popover */
  #global-nav {
    overflow: visible;
  }
  /* when open, pin the panel to the viewport with side gutters */
  .location-dropdown {
    position: fixed; /* escape local bounds */
    top: calc(var(--global-nav-height, 64px) + 8px);
    left: 12px;
    right: 12px; /* centered by left+right */
    min-width: 0; /* override 280px */
    width: auto;
    max-width: 420px; /* nice cap */
    margin: 0 auto;
    transform: none !important; /* cancel translateY */
    z-index: 1100; /* above nav (1000) */
  }
  /* if you have a little caret/arrow, hide it on mobile */
  .location-dropdown::before,
  .location-dropdown::after {
    display: none !important;
  }
}
/* Guard for all sizes: never exceed viewport width */
.location-dropdown {
  max-width: min(420px, 92vw);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.25rem;
  border-radius: 6px;
  font-weight: bold;
  background: var(--clr-hot-pink);
  color: white;
  transition: background 0.3s ease;
  gap: 0.5rem;
  text-decoration: none;
}

.btn img {
  width: 16px;
  height: 16px;
  margin-left: 0.5rem;
  vertical-align: middle;
  display: inline-block;
}

.btn-primary-outline {
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--clr-hot-pink);
  text-decoration: none;
  padding: 10px 16px;
  border: 1px solid var(--clr-hot-pink);
  border-radius: 1.125rem;
  font-weight: bold;
  text-transform: uppercase;
  line-height: 1;
}

.btn-primary-outline:hover,
.btn-primary-outline:focus-visible {
  color: white;
}

.btn-primary-outline.donate-btn {
  color: var(--clr-off-white);
  border-color: var(--clr-off-white);
}

.donate-btn:hover,
.donate-btn:focus-visible {
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--primary) 26%, transparent);
  border-color: color-mix(in srgb, var(--clr-off-white) 55%, transparent);
  outline: none;
}

.btn-secondary {
  background: #eee;
  color: #000;
}

.btn:hover {
  background: color-mix(in srgb, var(--clr-hot-pink) 80%, white);
}

.landing-btn {
  color: #000 !important;
  border: 1px solid black;
  border-radius: 20px;
  font-weight: 300;
  padding: 10px 20px;
  font-size: 1.2em;
  width: 300px;
  height: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
}

.landing-btn:hover {
  background: var(--clr-lilac);
  color: #fff !important;
  border: none;
}

.landing-btn.fort-lauderdale:hover {
  background: var(--clr-lime-green);
  color: #000 !important;
}

.btn-dark-green {
  background: var(--clr-dark-green);
  color: white;
  border-radius: 100vw;
}

.btn-primary,
.btn-outline {
  display: inline-block;
  padding: 0.85rem 1.5rem;
  border-radius: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-decoration: none;
  transition: transform 0.06s ease, background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.btn-primary {
  background: var(--clr-hot-pink);
  color: #fff;
}

.btn-primary:hover {
  background: var(--clr-lilac);
}

.btn-primary:active {
  transform: translateY(1px);
}

.btn-outline {
  background: transparent;
  border: 2px solid var(--clr-indigo, #3D2666);
  color: var(--clr-indigo, #3D2666);
}

.btn-outline:hover {
  background: var(--clr-lilac, #6B5AA6);
  border-color: var(--clr-lilac, #6B5AA6);
  color: #fff;
}

.btn-outline:active {
  transform: translateY(1px);
}

/* ---------- Base Card ---------- */
.card {
  --card-bg: #fff;
  --card-radius: 12px;
  --card-shadow: 0 4px 8px rgba(0,0,0,.10);
  --card-border: var(--category-color);
  --card-pad: 1.5rem;
  --card-title-size: clamp(1.5rem, 2vw + 1rem, 1.875rem);
  --card-title-weight: 800;
  --card-title-align: center;
  --card-text: var(--clr-text);
  /* logo/title tokens (overridable by utilities) */
  --card-logo-h: clamp(32px, 3.2vw, 56px); /* target max height for logo */
  --card-logo-w: 20rem; /* optional max width cap */
  --card-title-min-h: auto;
  background: var(--card-bg);
  border-radius: var(--card-radius);
  box-shadow: var(--card-shadow);
  border: 1px solid var(--card-border);
  overflow: hidden;
  text-align: left;
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.card:where(:hover, :focus-within) {
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}

.card-body {
  padding: var(--card-pad);
  color: var(--card-text);
}

/* ---------- Title (logo-friendly + no clipping) ---------- */
.card-title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding-inline: 0.25rem;
  margin: 0 0 0.5rem 0;
  inline-size: 100%;
  /* tall enough for logo; if text fallback shows, it can wrap */
  min-block-size: max(var(--card-title-min-h), var(--card-logo-h));
  font-weight: var(--card-title-weight);
  font-size: var(--card-title-size);
  line-height: 1.1;
  text-align: var(--card-title-align);
  color: var(--card-text);
  /* IMPORTANT: let children paint; we’ll prevent overflow by shrinking */
  overflow: visible;
}

/* Proportional logo sizing: shrink to fit (width & height), never crop */
.card-title-logo {
  display: block;
  box-sizing: border-box;
  max-inline-size: min(100%, var(--card-logo-w)); /* width cap */
  max-block-size: var(--card-logo-h); /* height cap */
  inline-size: auto; /* keep aspect ratio */
  block-size: auto; /* keep aspect ratio */
  object-fit: contain;
  flex: 0 1 auto; /* allow shrink in flex */
  min-inline-size: 0; /* critical for flex shrink */
  vertical-align: middle;
}

/* Fallback text: wrap instead of clipping if logo fails to load */
.card-title .card-title-text {
  max-inline-size: 100%;
  white-space: normal;
  word-break: break-word;
}

/* When a logo is present, hide the visible fallback text but keep it accessible */
.card-title:has(.card-title-logo) .card-title-text {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
  padding: 0;
  margin: -1px;
}

/* Legacy accent styling (when using text titles) */
.card-title span {
  color: var(--category-color);
}

.card-title .accent {
  position: relative;
  color: var(--card-text);
}

.card-title .accent::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  bottom: -0.15em;
  block-size: 0.22em;
  border-radius: 999px;
  background: var(--category-color);
  opacity: 0.35;
}

.card-title:has(.card-title-logo) .accent::after {
  display: none;
}

/* ---------- Variant: image-top (current) ---------- */
.card-image .card-media img {
  display: block;
  inline-size: 100%;
  block-size: 80px;
  object-fit: cover;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.card-image {
  --card-title-min-h: clamp(36px, 3.6vw, 56px);
}

/* ---------- Variant: panel (new) ---------- */
.card-panel {
  --card-bg: color-mix(in oklab, var(--category-color) 12%, #fff);
  --card-border: color-mix(in oklab, var(--category-color) 35%, #fff);
  --card-radius: 16px;
  --card-pad: clamp(1.25rem, 2vw + 1rem, 2rem);
  --card-title-size: clamp(1.75rem, 1.2vw + 1.5rem, 2.25rem);
  --card-title-align: center;
  --card-title-min-h: clamp(40px, 4vw, 64px);
}

.card-panel .card-media {
  display: none;
}

.card-panel .card-body > p {
  max-inline-size: 62ch;
  margin-inline: auto;
}

.card-panel .card-body {
  padding-inline: 1rem;
  padding-block: 2rem;
}

/* Card Actions */
.card-actions {
  margin-top: 1.5rem;
  text-align: center;
}

.card-actions .btn {
  width: 100%;
  max-width: 200px;
}

/* ---------- Size helpers (optional) ---------- */
.card-sm {
  --card-pad: 1rem;
  --card-title-size: clamp(1.25rem, 1.2vw + .9rem, 1.5rem);
}

.card-lg {
  --card-pad: 2rem;
  --card-title-size: clamp(2rem, 2vw + 1.5rem, 2.5rem);
}

/* === iOS fix: <img> inside flex was collapsing to 0×0.
	  Give logos an explicit height and let width auto-scale. === */
.card-title-logo {
  height: var(--card-logo-h); /* uses token (clamp/px) */
  width: auto;
  display: inline-block; /* keeps baseline/vertical-align working */
  vertical-align: middle;
}

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

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

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

.flex-between {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.grid-3 {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, 1fr);
}

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

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

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

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

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

.hidden {
  display: none !important;
}

.grid-4 {
  display: grid;
  gap: 0.75rem;
  grid-template-columns: repeat(4, 1fr);
  /* align-items: start;
  justify-content: center;
  margin: 0 auto; */
}

@media (max-width: 1200px) {
  .grid-4, .grid-3 {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 900px) {
  .grid-4, .grid-3 {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 600px) {
  .grid-4, .grid-3 {
    grid-template-columns: 1fr;
  }
}
.list-unstyled {
  list-style: none;
}

/* Thumbnail base */
.thumbnail-img {
  border-radius: 1rem;
}

/* ---- Shadow core ---- */
.u-shadow {
  /* configurable pieces */
  --shadow-offset: 1rem; /* magnitude */
  --shadow-blur: 0; /* 0 keeps it crisp */
  --shadow-spread: 0; /* 0 = solid block */
  --shadow-opacity: 1; /* 0–1 */
  --shadow-color-base: currentColor;
  /* these are set by direction utilities */
  --shadow-x: var(--shadow-offset);
  --shadow-y: var(--shadow-offset);
  /* fallback color (no rgb(from) support) */
  --shadow-color: var(--shadow-color-base);
  box-shadow: var(--shadow-x) var(--shadow-y) var(--shadow-blur) var(--shadow-spread) var(--shadow-color);
}

/* derive alpha from any base color if supported */
@supports (color: rgb(from #000 r g b/1)) {
  .u-shadow {
    --shadow-color: rgb(from var(--shadow-color-base) r g b / var(--shadow-opacity));
  }
}
/* ---- Direction (choose one) ---- */
.shadow-dir-bl {
  --shadow-x: calc(-1 * var(--shadow-offset));
  --shadow-y: var(--shadow-offset);
} /* bottom-left */
.shadow-dir-br {
  --shadow-x: var(--shadow-offset);
  --shadow-y: var(--shadow-offset);
} /* bottom-right */
.shadow-dir-tl {
  --shadow-x: calc(-1 * var(--shadow-offset));
  --shadow-y: calc(-1 * var(--shadow-offset));
} /* top-left */
.shadow-dir-tr {
  --shadow-x: var(--shadow-offset);
  --shadow-y: calc(-1 * var(--shadow-offset));
} /* top-right */
/* ---- Offset magnitude ---- */
.shadow-offset-sm {
  --shadow-offset: .5rem;
}

.shadow-offset-md {
  --shadow-offset: 1rem;
}

.shadow-offset-lg {
  --shadow-offset: 1.5rem;
}

.shadow-offset-xl {
  --shadow-offset: 2rem;
}

/* ---- Crisp vs soft (optional) ---- */
.shadow-hard {
  --shadow-blur: 0;
  --shadow-spread: 0;
}

.shadow-soft {
  --shadow-blur: clamp(8px, 1.2vw, 16px);
  --shadow-spread: 0;
}

/* ---- Color utilities (or keep currentColor) ---- */
.shadow-color-current {
  --shadow-color-base: currentColor;
}

.shadow-color-pink {
  --shadow-color-base: var(--clr-hot-pink);
}

.shadow-color-lime {
  --shadow-color-base: var(--clr-lime-green);
}

.shadow-color-soft-pink {
  --shadow-color-base: var(--clr-soft-pink);
}

.shadow-color-soft-green {
  --shadow-color-base: var(--clr-soft-green);
}

.shadow-color-indigo {
  --shadow-color-base: var(--clr-indigo);
}

/* Alpha helpers */
.shadow-opacity-100 {
  --shadow-opacity: 1;
}

.shadow-opacity-80 {
  --shadow-opacity: .8;
}

.shadow-opacity-60 {
  --shadow-opacity: .6;
}

/* Category color utilities (already added previously) */
.cat-pink {
  --category-color: var(--clr-hot-pink);
}

.cat-soft-pink {
  --category-color: var(--clr-soft-pink);
}

.cat-orange {
  --category-color: var(--clr-orange);
}

.cat-green {
  --category-color: var(--clr-lime-green);
}

.cat-lilac {
  --category-color: var(--clr-lilac);
}

.cat-dark-purple {
  --category-color: var(--clr-dark-purple);
}

.cat-indigo {
  --category-color: var(--clr-indigo);
}

.cat-current {
  --category-color: currentColor;
}

/* Logo size utilities (override the default var) */
.logo-h-36 {
  --card-logo-h: 36px;
}

.logo-h-44 {
  --card-logo-h: 44px;
}

.logo-h-56 {
  --card-logo-h: 56px;
}

.logo-h-64 {
  --card-logo-h: 64px;
}

.logo-w-14 {
  --card-logo-w: 14rem;
}

.logo-w-20 {
  --card-logo-w: 20rem;
}

/* Accessibility helper */
.visually-hidden {
  position: absolute !important;
  inline-size: 1px;
  block-size: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* Size utilities (override the CSS vars without inline styles) */
.pill-h-48 {
  --pill-logo-h: 48px;
}

.pill-h-56 {
  --pill-logo-h: 56px;
}

.pill-h-64 {
  --pill-logo-h: 64px;
}

.pill-w-20 {
  --pill-logo-w: 20rem;
}

.pill-w-24 {
  --pill-logo-w: 24rem;
}

.pill-w-28 {
  --pill-logo-w: 28rem;
}

/* Placeholders */
.logo-placeholder {
  background: var(--clr-off-white);
  width: 100px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  color: inherit;
}

.hero {
  background: var(--bg-color);
  color: var(--clr-text);
  padding-block: calc(var(--spacer) * 5);
}
.hero .hero-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  /* text-align: center; */
}
.hero .hero-text {
  margin-bottom: 2rem;
}
.hero .hero-text #page-title {
  /* font-size: clamp(1.5rem, 2vw + 1rem, 2.5rem); */
  /* line-height: 1.3; */
  color: var(--clr-indigo);
}
.hero .hero-text #page-title .highlight {
  color: var(--clr-hot-pink);
  font-weight: bold;
}
.hero .hero-text #page-title .nowrap {
  white-space: nowrap;
}
.hero .hero-video-wrapper {
  position: relative;
  width: 100%;
  max-width: 1200px;
  aspect-ratio: 16/9;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
  border-radius: 40px;
}
.hero .hero-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero .video-play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--clr-hot-pink);
  background: none;
  border: none;
  cursor: pointer;
  z-index: 2;
}
.hero .video-play-btn img, .hero .video-play-btn svg {
  width: 70px;
  height: 70px;
}
.hero .video-play-btn .play-icon {
  color: var(--clr-hot-pink);
}
.hero .video-play-btn.hidden {
  display: none;
}

/* Heading Pill */
.heading-pill-wrapper {
  position: absolute;
  left: 0;
  width: 60%;
  /* background: var(--clr-indigo); */
  /* color: var(--clr-off-white); */
  /*set radius to a really large value for the pill shape*/
  border-top-right-radius: 100vw;
  border-bottom-right-radius: 100vw;
  padding: 0.75rem 0;
  z-index: 1;
  /* h2 {
      margin-bottom: 0;
  } */
}

.heading-pill-wrapper.secondary {
  background-color: var(--clr-indigo);
  color: var(--clr-off-white);
}

.heading-pill-wrapper.bottom {
  bottom: 2.5rem;
}

.heading-pill-wrapper.top {
  /* top: -1rem; */
  bottom: unset;
}

.heading-pill-wrapper .container {
  display: flex;
  align-items: center;
}

.heading-pill {
  color: var(--clr-off-white);
  font-weight: 900;
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  padding-left: 1rem;
  width: inherit;
  text-align: right;
  text-transform: uppercase;
}

/**********/
/* Programs Section */
/**********/
.section-hero {
  position: relative;
  width: 100%;
  /* min-height: 400px; */
  min-height: 150px;
  overflow: hidden;
}
.section-hero img {
  width: 100%;
  display: block;
  object-fit: cover;
}

.hero-overlay-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: var(--clr-off-white);
  padding: 0 1rem;
  width: 100%;
  max-width: 800px;
  z-index: 1;
}
.hero-overlay-text h2, .hero-overlay-text .h2 {
  color: var(--clr-off-white);
}
.hero-overlay-pink {
  position: absolute;
  inset: 0;
  background: var(--clr-soft-pink, rgba(255, 204, 229, 0.6));
  mix-blend-mode: multiply;
  z-index: 0;
  pointer-events: none;
}

.section-bkg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.program-category {
  background-color: var(--bg-color);
  padding: 3rem 0;
  overflow-x: hidden;
}

/* White content block */
.program-category .category-content {
  background-color: var(--bg-color);
  border-radius: 0.5rem;
  padding: 2rem 0;
  margin: 0 auto;
  width: 100%;
  max-width: 1200px;
}

@media (max-width: 1200px) {
  .program-category .category-content {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}
/* Category Colors */
/* Assign a category color via CSS variable */
.program-category.support-services {
  --category-color: var(--clr-hot-pink);
  background-color: var(--bg-color);
}

.program-category.stem {
  --category-color: var(--clr-lime-green);
  background-color: var(--bg-color);
}

.program-category.stem h2, .program-category.stem .h2 {
  color: var(--clr-indigo);
}

.program-category.stem .category-heading-pill::after {
  content: "";
  position: absolute;
  top: auto;
  right: -75vw;
  bottom: auto;
  transform: translateY(37%);
  height: 0.7em;
  left: calc(100% + 1rem);
  background: var(--clr-lime-green);
  border-radius: 999px;
  z-index: -1;
}

/* .program-category.education {
    --category-color: var(--clr-orange);
    background-color: var(--clr-soft-pink);
} */
.category-heading-pill-wrapper {
  margin-bottom: 2rem;
  position: relative;
  overflow: visible;
}

.category-heading-pill {
  position: relative;
  display: inline-block;
  font-weight: 800;
  text-transform: uppercase;
  font-size: clamp(2.5rem, 12vw, 5rem);
  line-height: 1.2;
  color: var(--category-color);
  z-index: 1;
}

.category-heading-pill::after {
  content: "";
  position: absolute;
  top: 50%; /* anchor to the vertical middle of the heading */
  left: calc(100% + 1rem);
  right: -75vw;
  transform: translateY(-50%); /* center the pill on that midpoint */
  height: 0.7em;
  background: color-mix(in srgb, currentColor 100%, transparent);
  border-radius: 999px;
  z-index: -1;
}

/* Utilized with pill logo svgs */
.pill-title {
  width: clamp(220px, 50vw, 525px);
  display: inline-block;
  /* display: inline-flex;                   /* don't stretch full width */
  /* inline-size: fit-content; */
  /* max-inline-size: 100%; */
  /* align-items: center; */
  /* justify-content: center; */
  /* gap: .5rem; */
  /* padding: clamp(.35rem, .6vw, .6rem) clamp(.9rem, 1.2vw, 1.25rem); */
  border-radius: 9999px;
  line-height: 1;
  margin: 0;
}

.pill-title::after {
  content: "";
  position: absolute;
  top: 0;
  right: -75vw;
  bottom: auto;
  transform: translateY(0%);
  height: 0.7em;
  left: calc(100% + 1rem);
  background: color-mix(in srgb, currentColor 100%, transparent);
  border-radius: 999px;
  z-index: -1;
}

/* The logo scales down proportionally and never overflows the pill */
.pill-logo {
  display: block;
  max-block-size: var(--pill-logo-h, clamp(40px, 4vw, 72px)); /* height cap */
  max-inline-size: min(100%, var(--pill-logo-w, 24rem)); /* width cap */
  inline-size: auto;
  block-size: auto;
  object-fit: contain;
  flex: 0 1 auto; /* allow shrinking inside the pill */
  min-inline-size: 0;
}

.program-category p {
  color: var(--clr-text);
  max-width: 700px;
  margin-bottom: 1rem;
  line-height: 1.5;
}

/* .thumbnail-img {
    border-radius: 1rem;
}
.thumbnail-img.shadow-bottom-left {
    box-shadow: -1rem 1rem 0 0 currentColor;
} */
/* Upcoming Events Section */
.program-category.section-upcoming-events {
  --category-color: var(--clr-lilac);
  background-color: var(--clr-soft-lilac);
}

.events-slider {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
}

.events-container {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}

.event-slide {
  display: none;
  animation: fadeIn 0.5s ease-in-out;
}

.event-slide.active {
  display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateX(20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
.event-card {
  background: var(--bg-color);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.event-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.event-content {
  padding: 2.5rem 2rem;
  text-align: center;
  min-height: 400px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.event-content h3, .event-content .h3 {
  font-size: 1.4rem;
  font-weight: 700;
  color: #DF44A6;
  margin-bottom: 0.75rem;
  line-height: 1.3;
}

.event-format {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--clr-lilac);
  margin-bottom: 0.5rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.event-audience {
  font-size: 0.9rem;
  color: #E89F56 !important;
  margin-bottom: 1rem;
  font-style: italic;
}

.event-date-bold {
  font-size: 2.5rem;
  font-weight: 800;
  color: #DF44A6 !important;
  margin-bottom: 0.5rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.event-time {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--clr-text);
  margin-bottom: 1.5rem;
}

.event-date {
  font-size: 1rem;
  font-weight: 600;
  color: var(--clr-lilac);
  margin-bottom: 0.25rem;
}

.event-location {
  font-size: 0.9rem;
  color: var(--clr-text-light);
  margin-bottom: 1rem;
  font-style: italic;
}

.event-location-pink {
  font-size: 1rem;
  font-weight: 600;
  color: #DF44A6 !important;
  margin-bottom: 1rem;
}

.bounce-text {
  font-size: 2rem;
  font-weight: 700;
  color: #DF44A6;
  text-align: center;
  display: block;
  margin: 0 auto;
}

/* Special styling for the coming soon slide */
.coming-soon-content {
  justify-content: flex-start !important;
  align-items: center !important;
  text-align: center !important;
  padding-top: 3rem !important;
}

.coming-soon-content .event-logo {
  margin-top: 1.5rem;
  text-align: center;
  width: 100%;
}

.event-logo {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 1.5rem;
  width: 100%;
  flex-shrink: 0;
  text-align: center;
}

.coming-soon-logo {
  max-width: 150px;
  height: auto;
  opacity: 0.9;
  display: block;
  margin: 0 auto;
  text-align: center;
}

.event-description {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--clr-text);
  margin-bottom: 1.5rem;
}

.rsvp-btn {
  background: var(--clr-lilac);
  color: white;
  border: none;
  padding: 0.75rem 2rem;
  border-radius: 25px;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.3s ease;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.rsvp-btn:hover {
  background: var(--clr-text);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.slider-controls {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  margin-top: 2rem;
}

.slider-btn {
  background: var(--clr-hot-pink);
  border: none;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(223, 68, 166, 0.3);
}

.slider-btn:hover {
  background: var(--clr-indigo);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(25, 22, 42, 0.3);
}

.slider-btn img {
  width: 20px;
  height: 20px;
  filter: brightness(0) invert(1);
}

.slider-dots {
  display: flex;
  gap: 0.5rem;
}

.dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--clr-soft-pink);
  cursor: pointer;
  transition: all 0.3s ease;
}

.dot.active {
  background: var(--clr-hot-pink);
  transform: scale(1.2);
}

/* Photo Link Section */
.photo-link-section {
  padding: 4rem 0;
  background: var(--bg-color);
}

.photo-link-card {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
  transition: transform 0.3s ease;
}

.photo-link-card:hover {
  transform: translateY(-5px);
}

.photo-link-image {
  width: 100%;
  height: 400px;
  overflow: hidden;
}

.photo-link-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.photo-link-card:hover .photo-link-image img {
  transform: scale(1.05);
}

.photo-link-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(223, 68, 166, 0.9) 0%, rgba(186, 146, 232, 0.9) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.photo-link-card:hover .photo-link-overlay {
  opacity: 1;
}

.photo-link-content {
  text-align: center;
  color: white;
  padding: 2rem;
}

.photo-link-content h3, .photo-link-content .h3 {
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 1rem;
}

.photo-link-content p {
  font-size: 1.1rem;
  margin-bottom: 2rem;
  line-height: 1.6;
}

.photo-link-btn {
  background: white;
  color: var(--clr-hot-pink);
  border: 2px solid white;
  padding: 1rem 2rem;
  font-weight: bold;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transition: all 0.3s ease;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.photo-link-btn:hover {
  background: transparent;
  color: white;
  border-color: white;
  transform: translateY(-2px);
}

.arrow-icon {
  width: 20px;
  height: 20px;
  transition: transform 0.3s ease;
}

.photo-link-btn:hover .arrow-icon {
  transform: translateX(4px);
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .events-slider {
    max-width: 100%;
  }
  .slider-controls {
    gap: 1rem;
  }
  .slider-btn {
    width: 40px;
    height: 40px;
  }
  .photo-link-image {
    height: 300px;
  }
  .photo-link-content h3, .photo-link-content .h3 {
    font-size: 1.5rem;
  }
  .photo-link-content p {
    font-size: 1rem;
  }
  /* Show overlay on mobile devices */
  /* .photo-link-overlay {
      opacity: 1;
  } */
}
/* hero base (un-nest SCSS) */
.hero {
  background: var(--bg-color);
  color: var(--clr-text);
  padding-block: calc(var(--spacer) * 5);
}

.hero .hero-container {
  display: flex;
  flex-direction: column;
  align-items: center; /* text-left on your H1 still applies */
}

.hero .hero-text {
  margin-bottom: 2rem;
}

/* responsive H1 — sane on phones */
.hero .hero-text #page-title {
  color: var(--clr-indigo);
  font-size: var(--display-lg, clamp(3rem, 2.6rem + 2.4vw, 4rem));
  line-height: var(--lh-tight, 1.1);
  letter-spacing: var(--track-tight, -0.015em);
  text-wrap: balance;
  margin: 0 0 0.5rem;
}

.hero .hero-text #page-title .highlight {
  color: var(--clr-hot-pink);
  font-weight: 700;
}

.hero .hero-text #page-title .nowrap {
  white-space: nowrap;
}

/* phones: step down size, allow the “nowrap” span to wrap */
@media (max-width: 640px) {
  .hero .hero-text #page-title {
    font-size: var(--display-md, clamp(2.4rem, 2rem + 2.4vw, 3.25rem));
    line-height: 1.15;
    letter-spacing: -0.01em;
  }
  .hero .hero-text #page-title .nowrap {
    white-space: normal;
  }
}
/* very small phones: clamp again to avoid 3+ lines */
@media (max-width: 380px) {
  .hero .hero-text #page-title {
    font-size: clamp(1.9rem, 6vw + 0.9rem, 2.4rem);
  }
}
/* video frame */
.hero .hero-video-wrapper {
  position: relative;
  width: 100%;
  max-width: 1200px;
  aspect-ratio: 16/9;
  overflow: hidden;
  border-radius: 40px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.hero .hero-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* === Fix: photo-link overlay should not auto-show on mobile === */
@media (max-width: 768px) {
  .photo-link-overlay {
    opacity: 0 !important;
    pointer-events: none !important;
  }
  .photo-link-card:hover .photo-link-overlay {
    opacity: 0 !important;
  }
  .photo-link-card {
    transform: none !important;
  }
  .photo-link-card:hover .photo-link-image img {
    transform: none !important;
  }
}
/* Touch devices (feature detect) */
@media (hover: none), (pointer: coarse) {
  .photo-link-overlay {
    opacity: 0 !important;
    pointer-events: none !important;
  }
  .photo-link-card:hover .photo-link-overlay {
    opacity: 0 !important;
  }
  .photo-link-card {
    transform: none !important;
  }
  .photo-link-card:hover .photo-link-image img {
    transform: none !important;
  }
}
/* =========================================================
HEADING-PILL SECTION (generic)
--------------------------------------------------------- */
.heading-pill-section {
  position: relative;
  margin-block: 4rem;
}

/* White rounded surface */
.heading-pill-section .section-surface {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  background: #fff; /* white background */
  border-radius: 56px;
  padding: clamp(2rem, 4vw, 3rem);
  /* extra top padding so content clears the overlapping pill */
  padding-top: clamp(4rem, 6vw, 5rem);
  box-shadow: 0 24px 60px rgba(20, 16, 40, 0.08);
  border: 1px solid color-mix(in srgb, var(--clr-charcoal, #000) 10%, transparent);
}

/* =========================================================
EXISTING HEADING PILL (scoped to this section)
--------------------------------------------------------- */
.heading-pill-section .heading-pill-wrapper {
  position: absolute;
  left: 0;
  width: 60%;
  border-top-right-radius: 100vw;
  border-bottom-right-radius: 100vw;
  padding: 0.75rem 0;
  z-index: 2; /* sit above the surface */
  /* default behavior = "top" overlap, like Our Story */
  top: 0;
  transform: translateY(-50%);
}

.heading-pill-wrapper h2, .heading-pill-wrapper .h2 {
  margin-bottom: 0;
}

.heading-pill-section .heading-pill-wrapper.secondary {
  background-color: var(--clr-indigo);
  color: var(--clr-off-white);
}

/* Optional placement modifiers (keep your API) */
.heading-pill-section .heading-pill-wrapper.bottom {
  bottom: 2.5rem;
  top: unset;
  transform: none;
}

.heading-pill-section .heading-pill-wrapper.top {
  top: 0;
  bottom: unset;
  transform: translateY(-50%);
}

.heading-pill-section .heading-pill-wrapper .container {
  display: flex;
  align-items: center;
}

.heading-pill-section .heading-pill {
  color: var(--clr-off-white);
  font-weight: 900;
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  padding-left: 1rem;
  width: inherit;
  text-align: right;
  text-transform: uppercase;
}

/* Content area grid (optional helper) */
.heading-pill-section .section-body {
  display: grid;
  gap: clamp(1.25rem, 2.5vw, 2rem);
}

/* If you drop sliders/cards inside, isolate for nice shadows */
.heading-pill-section .event-card,
.heading-pill-section .events-slider {
  isolation: isolate;
}

/* =========================================================
RESPONSIVE TWEAKS
--------------------------------------------------------- */
@media (max-width: 900px) {
  .heading-pill-section .section-surface {
    border-radius: 36px;
  }
}
@media (max-width: 700px) {
  /* Make it behave like Our Story on mobile */
  .heading-pill-section .heading-pill-wrapper {
    left: 0; /* anchor to the left, not centered */
    right: auto;
    width: clamp(70%, 86vw, 520px); /* pill length similar to Our Story */
    transform: translateY(-50%); /* keep the overlap */
    /* round only the right side (like desktop/Our Story) */
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 100vw;
    border-bottom-right-radius: 100vw;
    text-align: left;
  }
  .heading-pill-section .heading-pill {
    text-align: left;
    padding-left: 1rem; /* restore left padding */
  }
  /* give a bit more clearance under the pill */
  .heading-pill-section .section-surface {
    padding-top: clamp(4.5rem, 10vw, 6rem);
  }
}
@layer infographic-impact {
  /* ===== Derived tokens (from vars) ===== */
  :root {
    --impact-page-bg: #fff;
    --impact-surface: #fff;
    --impact-text: var(--clr-indigo); /* headings & card text */
    --impact-muted: var(--clr-text); /* secondary text */
    /* subtle border/shadow tints made from indigo */
    --impact-border: color-mix(in srgb, var(--clr-indigo) 12%, transparent);
    --impact-shadow: color-mix(in srgb, var(--clr-indigo) 12%, transparent);
    --impact-shadow-hover: color-mix(in srgb, var(--clr-indigo) 18%, transparent);
  }
  /* ===== Section shell ===== */
  #section-our-impact {
    margin-top: 10vh;
    /* padding: 60px 0; */
    /* background: var(--impact-page-bg); */
    background: var(--bg-color);
  }
  .section-content {
    display: flex;
    justify-content: center;
    padding: 0 20px;
    overflow: visible;
  }
  /* .container {
  	max-width: 1200px;
  	margin: 0 auto;
  	padding: 0 20px;
  } */
  /* ===== Fluid art-directed canvas (desktop/tablet) ===== */
  .infographic-container {
    width: min(100%, 1260px);
    aspect-ratio: 1260/688;
    /* base64 SVG artwork (colors are baked into the image) */
    position: relative;
    margin: 0 auto;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 32px var(--impact-shadow);
    background: url("../svgs/our-impact-2024-base.svg") no-repeat center center;
    background-size: 95% 95%;
    background-color: white;
  }
  /* ===== Cards ===== */
  .stat-card {
    position: absolute;
    z-index: 1;
    background: var(--impact-surface);
    border-radius: 12px;
    padding: var(--spacer);
    box-shadow: 0 6px 18px var(--impact-shadow);
    border: 1px solid var(--impact-border);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    animation: fade-in-up 0.6s ease forwards;
    opacity: 0;
    /* fluid size with safety bounds */
    width: clamp(180px, 13vw, 240px);
    min-height: 110px;
    height: auto;
  }
  .stat-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px var(--impact-shadow-hover);
  }
  .stat-card h3, .stat-card .h3 {
    color: var(--impact-text);
    font-weight: var(--fw-extrabold);
    margin: 0 0 8px 0;
    line-height: 1.2;
    font-size: var(--step-1);
  }
  .stat-card p {
    color: var(--impact-text);
    margin: 0;
    line-height: 1.35;
    font-size: var(--step--1);
    font-weight: var(--fw-semibold);
    text-transform: uppercase;
    overflow-wrap: anywhere;
    hyphens: auto;
  }
  /* ===== Positions (no overlaps, clear end-circles) ===== */
  .infographic-container .card-1 {
    left: 10.4%;
    top: 74.4%;
    animation-delay: 0.1s;
  } /* Board Members */
  .infographic-container .card-2 {
    left: 17.2%;
    top: 35.8%;
    animation-delay: 0.2s;
  } /* Staff & Volunteers */
  .infographic-container .card-3 {
    left: 43%;
    top: 19.8%;
    animation-delay: 0.3s;
  } /* Donations */
  .infographic-container .card-4 {
    left: 75%;
    top: 42.2%;
    animation-delay: 0.4s;
  } /* Programs Conducted */
  .infographic-container .card-5 {
    left: 70.8%;
    top: 82.6%;
    animation-delay: 0.5s;
  } /* Girls Transformed */
  /* Entrance animation */
  @keyframes fade-in-up {
    from {
      opacity: 0;
      transform: translateY(20px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
  /* ===== Medium-width collision guards ===== */
  @media (max-width: 1100px) {
    .infographic-container .card-3 {
      top: 15%;
      left: 47.8%;
    }
    .infographic-container .card-4 {
      top: 15.4%;
      left: 70.8%;
    }
  }
  @media (max-width: 920px) {
    .infographic-container .card-3 {
      top: 20%;
      left: 43%;
    }
    .infographic-container .card-4 {
      top: 40.6%;
    }
    .infographic-container .card-5 {
      top: 74.6%;
      left: 62.8%;
    }
  }
  /* ===== Mobile: hide desktop cards, show chart + mobile cards ===== */
  .mobile-chart,
  .mobile-grid {
    display: none;
  }
  @media (max-width: 768px) {
    .infographic-container {
      width: 100%;
      aspect-ratio: auto;
      position: static;
      background: var(--impact-surface);
      padding: 20px;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 30px;
      border-radius: 12px;
      box-shadow: 0 4px 16px var(--impact-shadow);
    }
    .stat-card {
      display: none !important;
    }
    .mobile-chart,
    .mobile-grid {
      display: block;
      width: 100%;
    }
    .mobile-chart {
      max-width: 240px;
      max-height: 240px;
      width: 200px;
      height: 200px;
      position: relative;
    }
    /* Recolor the inline SVG using your tokens */
    .mobile-chart svg circle:nth-of-type(1) {
      stroke: var(--clr-off-white) !important;
    }
    .mobile-chart svg circle:nth-of-type(2) {
      stroke: var(--primary) !important;
    }
    .chart-center {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      text-align: center;
      background: var(--impact-surface);
      border-radius: 50%;
      width: 120px;
      height: 120px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      box-shadow: 0 4px 12px var(--impact-shadow);
    }
    .chart-title {
      font-size: 18px;
      color: var(--clr-indigo);
      font-weight: 700;
    }
    .chart-subtitle {
      font-size: 12px;
      color: var(--impact-muted);
      margin-top: 4px;
    }
    .mobile-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 15px;
      width: 100%;
      max-width: 400px;
    }
    .mobile-card {
      background: var(--impact-surface);
      color: var(--impact-text);
      padding: 20px;
      border-radius: 12px;
      text-align: center;
      box-shadow: 0 4px 16px var(--impact-shadow);
      border-left: 4px solid;
      transition: transform 0.3s ease, box-shadow 0.3s ease;
      animation: fade-in-up 0.6s ease forwards;
    }
    .mobile-card:hover {
      transform: translateY(-4px);
      box-shadow: 0 8px 24px var(--impact-shadow-hover);
    }
    .mobile-card h3, .mobile-card .h3 {
      font-size: 24px;
      margin: 0 0 8px 0;
      font-weight: 700;
      color: var(--impact-text);
    }
    .mobile-card p {
      font-size: 14px;
      color: var(--impact-muted);
      line-height: 1.3;
      margin: 0;
    }
    /* left-border accents use your brand vars */
    .mobile-card:nth-child(1) {
      border-left-color: var(--clr-indigo);
      animation-delay: 0.1s;
    }
    .mobile-card:nth-child(2) {
      border-left-color: var(--clr-lilac);
      animation-delay: 0.2s;
    }
    .mobile-card:nth-child(3) {
      border-left-color: var(--clr-lime-green);
      animation-delay: 0.3s;
    }
    .mobile-card:nth-child(4) {
      border-left-color: var(--clr-orange);
      animation-delay: 0.4s;
    }
    .mobile-card:nth-child(5) {
      border-left-color: var(--clr-hot-pink);
      animation-delay: 0.5s;
    }
    .mobile-card.featured {
      grid-column: 1/-1;
      background: linear-gradient(135deg, var(--clr-indigo) 0%, var(--secondary) 100%);
      color: var(--impact-surface);
      border-left: none;
      border: 2px solid var(--clr-hot-pink);
    }
    .mobile-card.featured h3, .mobile-card.featured .h3 {
      color: var(--impact-surface);
    }
    .mobile-card.featured p {
      color: color-mix(in srgb, var(--impact-surface) 90%, transparent);
    }
  }
  @media (max-width: 480px) {
    .infographic-container {
      padding: 15px;
      gap: 15px;
    }
    .mobile-card {
      padding: 16px;
    }
    .mobile-card h3, .mobile-card .h3 {
      font-size: 22px;
    }
    .mobile-card p {
      font-size: 13px;
    }
  }
}
@layer page-thank-you {
  .thank-you-page {
    /* light page wash */
    background: var(--clr-soft-pink, #fde8f4);
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
  }
  .thank-you-page .main-content {
    flex: 1 0 auto;
  }
  .thank-you-page footer {
    margin-top: auto;
  }
  .thankyou-hero {
    padding-block: clamp(3rem, 7vw, 6rem);
  }
  .thankyou-card {
    background: #fff;
    border-radius: 28px;
    padding: clamp(1.25rem, 4vw, 3rem);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.06);
    text-align: center;
    max-width: 960px;
    margin-inline: auto;
  }
  .brand-wordmark {
    display: block;
    margin: 0 auto clamp(0.5rem, 2vw, 1rem);
    height: clamp(36px, 6vw, 60px);
  }
  .eyebrow {
    font-weight: 700;
    letter-spacing: 0.02em;
    color: var(--clr-indigo, #3D2666);
    margin: 0.25rem 0 0.5rem;
  }
  .big-thanks {
    font-size: clamp(1.5rem, 4vw, 2.4rem);
    line-height: 1.15;
    color: var(--clr-text, #1a1a1a);
    margin: 0 0 0.5rem;
  }
  .subcopy {
    color: var(--clr-indigo, #3D2666);
    opacity: 0.9;
    font-size: clamp(1rem, 2.2vw, 1.125rem);
    max-width: 46ch;
    margin: 0 auto 1.25rem;
  }
  .cta-row {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    flex-wrap: wrap;
    margin: 0 0 1.25rem;
  }
  .social-pills {
    display: flex;
    gap: 0.75rem;
    justify-content: center;
    margin-top: 0.75rem;
  }
  .social-pills .pill {
    height: 44px;
    width: 44px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--clr-hot-pink, #DF44A6);
    box-shadow: 0 6px 18px rgba(223, 68, 166, 0.25);
    transition: transform 0.06s ease, filter 0.2s ease;
  }
  .social-pills .pill:hover {
    filter: brightness(1.05);
  }
  .social-pills .pill:active {
    transform: translateY(1px);
  }
  .social-pills .pill img {
    width: 22px;
    height: 22px;
    display: block;
    filter: brightness(0) invert(1); /* make white if the SVGs are dark */
  }
}
/* Former special-case */
.gradient-background {
  width: 80%;
  margin: 0 auto;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  /* Gradient from brand colors */
  background: linear-gradient(135deg, color-mix(in srgb, var(--clr-lime-green) 60%, var(--clr-soft-green)) 0%, color-mix(in srgb, var(--clr-hot-pink) 65%, var(--clr-soft-pink)) 25%, color-mix(in srgb, var(--clr-lilac) 60%, var(--clr-soft-lilac)) 50%, color-mix(in srgb, var(--clr-lilac) 50%, var(--clr-soft-lilac)) 75%, color-mix(in srgb, var(--clr-orange) 65%, var(--clr-soft-orange)) 100%);
  border-radius: 0 200px 0 200px; /* opposing rounded corners */
  overflow: hidden;
  /* Keep your organic mask */
  /* clip-path: polygon(
  	0% 20%, 
  	15% 0%, 
  	35% 5%, 
  	60% 0%, 
  	80% 10%, 
  	100% 30%, 
  	95% 50%, 
  	100% 75%, 
  	85% 90%, 
  	60% 95%, 
  	40% 100%, 
  	20% 95%, 
  	5% 80%, 
  	0% 60%
  ); */
}

/* Partner Logos: Infinite Slider
   - Duplicate your logo items once in the markup for a seamless loop.
   - Edge spacers (via ::before/::after) prevent first/last logos from looking clipped.
   - Fixed cell widths + inner padding ensure consistent spacing across logos.
*/
.partner-logos-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  margin-top: 2rem;
  /* Tweakable vars */
  --gap: 3rem; /* space between cells */
  --edge-pad: 80px; /* invisible spacers at track ends */
  --logo-h: 60px; /* default logo height */
  --cell-w: 220px; /* fixed width per logo cell */
  --inner-pad: 14px; /* minimum padding inside each cell */
  --speed: 28s; /* loop duration */
}

.partner-logos-slider .slider-track {
  display: flex;
  align-items: center;
  gap: var(--gap);
  width: max-content;
  will-change: transform;
  animation: slideLogos var(--speed) linear infinite;
}

/* Edge spacers so logos don’t appear chopped */
.partner-logos-slider .slider-track::before,
.partner-logos-slider .slider-track::after {
  content: "";
  flex: 0 0 var(--edge-pad);
  height: 1px; /* keeps layout stable */
}

.partner-logos-slider .slider-item {
  flex: 0 0 var(--cell-w);
  width: var(--cell-w);
  padding-inline: var(--inner-pad);
  display: flex;
  align-items: center;
  justify-content: center;
}

.partner-logos-slider .slider-item img {
  display: block;
  height: var(--logo-h);
  width: auto;
  max-width: 100%;
  object-fit: contain;
  filter: brightness(0) invert(1);
  transition: transform 0.25s ease;
}

.partner-logos-slider .slider-item img:hover {
  transform: scale(1.06);
}

/* Duplicate set technique: slide width of one full set (50% of track when duplicated) */
@keyframes slideLogos {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
/* Pause on hover */
.partner-logos-slider:hover .slider-track {
  animation-play-state: paused;
}

/* Section-specific wrapper */
#section-special-thanks .partner-logos-slider {
  z-index: 2;
  padding: 1rem 0;
}

/* Responsive tweaks */
@media (max-width: 768px) {
  .partner-logos-slider {
    --gap: 2.25rem;
    --edge-pad: 56px;
    --logo-h: 50px;
    --cell-w: 190px;
    --inner-pad: 12px;
    --speed: 26s;
  }
}
@media (max-width: 480px) {
  .partner-logos-slider {
    --gap: 1.75rem;
    --edge-pad: 44px;
    --logo-h: 44px;
    --cell-w: 160px;
    --inner-pad: 10px;
    --speed: 24s;
  }
}
.events-slider {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
}

.events-container {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
}

.event-slide {
  display: none;
  animation: fadeIn 0.5s ease-in-out;
}

.event-slide.active {
  display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateX(20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
.event-card {
  background: var(--bg-color);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.event-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.event-content {
  padding: 2.5rem 2rem;
  text-align: center;
  min-height: 400px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* text styles you already had */
.event-content h3, .event-content .h3 {
  font-size: 1.4rem;
  font-weight: 700;
  color: #DF44A6;
  margin-bottom: 0.75rem;
  line-height: 1.3;
}

.event-format {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--clr-lilac);
  margin-bottom: 0.5rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.event-audience {
  font-size: 0.9rem;
  color: #E89F56 !important;
  margin-bottom: 1rem;
  font-style: italic;
}

.event-date-bold {
  font-size: 2.5rem;
  font-weight: 800;
  color: #DF44A6 !important;
  margin-bottom: 0.5rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.event-time {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--clr-text);
  margin-bottom: 1.5rem;
}

.event-date {
  font-size: 1rem;
  font-weight: 600;
  color: var(--clr-lilac);
  margin-bottom: 0.25rem;
}

.event-location {
  font-size: 0.9rem;
  color: var(--clr-text-light);
  margin-bottom: 1rem;
  font-style: italic;
}

.event-location-pink {
  font-size: 1rem;
  font-weight: 600;
  color: #DF44A6 !important;
  margin-bottom: 1rem;
}

.event-description {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--clr-text);
  margin-bottom: 1.5rem;
}

/* coming soon */
.bounce-text {
  font-size: 2rem;
  font-weight: 700;
  color: #DF44A6;
  text-align: center;
  display: block;
  margin: 0 auto;
}

.coming-soon-content {
  justify-content: flex-start !important;
  align-items: center !important;
  text-align: center !important;
  padding-top: 3rem !important;
}

.coming-soon-content .event-logo {
  margin-top: 1.5rem;
  text-align: center;
  width: 100%;
}

.event-logo {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 1.5rem;
  width: 100%;
  flex-shrink: 0;
  text-align: center;
}

.coming-soon-logo {
  max-width: 150px;
  height: auto;
  opacity: 0.9;
  display: block;
  margin: 0 auto;
  text-align: center;
}

.rsvp-btn {
  background: var(--clr-lilac);
  color: #fff;
  border: none;
  padding: 0.75rem 2rem;
  border-radius: 25px;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.3s ease;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.rsvp-btn:hover {
  background: var(--clr-text);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.slider-controls {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  margin-top: 2rem;
}

.slider-btn {
  background: var(--clr-hot-pink);
  border: none;
  border-radius: 50%;
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(223, 68, 166, 0.3);
}

.slider-btn:hover {
  background: var(--clr-indigo);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(25, 22, 42, 0.3);
}

.slider-btn img {
  width: 20px;
  height: 20px;
  filter: brightness(0) invert(1);
}

.slider-dots {
  display: flex;
  gap: 0.5rem;
}

/* now dots are buttons (for a11y) */
.slider-dots .dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--clr-soft-pink);
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: transform 0.2s ease, background 0.2s ease;
}

.slider-dots .dot.active {
  background: var(--clr-hot-pink);
  transform: scale(1.2);
}

@media (max-width: 768px) {
  .events-slider {
    max-width: 100%;
  }
  .slider-controls {
    gap: 1rem;
  }
  .slider-btn {
    width: 40px;
    height: 40px;
  }
}
/* ===== Promo Popup ===== */
.promo-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: none;
}

.promo-modal.is-open {
  display: block;
}

.promo-modal .promo-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  opacity: 0;
  transition: opacity 0.18s ease-out;
}

.promo-modal.is-open .promo-backdrop {
  opacity: 1;
}

.promo-modal .promo-dialog {
  position: relative;
  box-sizing: border-box;
  max-width: min(92vw, 760px);
  max-height: 92dvh;
  margin: 6vh auto;
  outline: none;
  background: #000; /* dark shell helps during image load */
  border-radius: 18px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
  transform: translateY(12px) scale(0.98);
  opacity: 0;
  transition: transform 0.2s ease-out, opacity 0.2s ease-out;
  overflow: hidden; /* clip overlay + image */
  display: grid;
}

.promo-modal.is-open .promo-dialog {
  transform: translateY(0) scale(1);
  opacity: 1;
}

/* ===== Hero: image behind, overlayed content on top ===== */
.promo-hero {
  position: relative;
  isolation: isolate; /* new stacking context */
  min-height: clamp(420px, 72vh, 820px);
}

/* Image layer */
.promo-poster-link,
.promo-poster {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100% !important;
  z-index: 0; /* bottom */
}

.promo-poster {
  object-fit: cover;
  filter: brightness(0.55); /* base darken */
}

/* Gradient layer (helps contrast) */
.promo-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.55) 0%, rgba(0, 0, 0, 0.35) 45%, rgba(0, 0, 0, 0.2) 70%, rgba(0, 0, 0, 0.1) 100%);
  pointer-events: none;
  z-index: 1; /* above image, below text */
}

/* Overlayed copy */
.promo-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: end;
  gap: 14px;
  padding: clamp(16px, 4vw, 28px);
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
  z-index: 2; /* above gradient */
}

#promo-modal-title {
  margin: 0;
  font-size: clamp(28px, 5vw, 52px);
  line-height: 1.05;
  color: #fff;
}

.promo-lead {
  margin: 0;
  font-size: clamp(15px, 2.1vw, 18px);
  max-width: 65ch;
}

/* Close button */
.promo-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: none;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
  cursor: pointer;
  font-size: 20px;
  line-height: 40px;
  z-index: 3; /* above overlay */
}

.promo-close:hover {
  background: #fff;
}

/* Buttons */
.promo-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-start;
  padding: 0; /* overlay spacing handles padding */
  background: transparent;
}

.promo-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 140px;
  height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  background: var(--clr-hot-pink, #e91e63);
  color: #fff;
  border: 0;
}

.promo-btn:hover {
  filter: brightness(1.05);
}

.promo-btn-secondary {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
  backdrop-filter: saturate(120%) blur(1.5px);
}

body.modal-open {
  overflow: hidden;
}

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

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .promo-modal .promo-backdrop,
  .promo-modal .promo-dialog {
    transition: none;
  }
}
/* Mobile tweaks */
@media (max-width: 480px) {
  .promo-modal .promo-dialog {
    max-width: 94vw;
    margin: clamp(8px, 3vh, 20px) auto;
    max-height: 94dvh;
  }
  .promo-hero {
    min-height: 70dvh;
  }
  .promo-actions {
    justify-content: center;
  }
}
/*# sourceMappingURL=main.css.map */
