@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap");/*
! tailwindcss v3.4.1 | MIT License | https://tailwindcss.com
*//*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}::before,
::after {
  --tw-content: '';
}/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */ /* 3 */
  tab-size: 4; /* 3 */
  font-family: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/abbr:where([title]) {
  text-decoration: underline dotted;
}/*
Remove the default font size and weight for headings.
*/h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}/*
Reset links to optimize for opt-in styling instead of opt-out.
*/a {
  color: inherit;
  text-decoration: inherit;
}/*
Add the correct font weight in Edge and Safari.
*/b,
strong {
  font-weight: bolder;
}/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}/*
Add the correct font size in all browsers.
*/small {
  font-size: 80%;
}/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}sub {
  bottom: -0.25em;
}sup {
  top: -0.5em;
}/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}/*
Remove the inheritance of text transform in Edge and Firefox.
*/button,
select {
  text-transform: none;
}/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/button,
[type='button'],
[type='reset'],
[type='submit'] {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}/*
Use the modern Firefox focus style for all focusable elements.
*/:-moz-focusring {
  outline: auto;
}/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/:-moz-ui-invalid {
  box-shadow: none;
}/*
Add the correct vertical alignment in Chrome and Firefox.
*/progress {
  vertical-align: baseline;
}/*
Correct the cursor style of increment and decrement buttons in Safari.
*/::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}/*
Remove the inner padding in Chrome and Safari on macOS.
*/::-webkit-search-decoration {
  -webkit-appearance: none;
}/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}/*
Add the correct display in Chrome and Safari.
*/summary {
  display: list-item;
}/*
Removes the default spacing and border for appropriate elements.
*/blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}fieldset {
  margin: 0;
  padding: 0;
}legend {
  padding: 0;
}ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}/*
Reset default styling for dialogs.
*/dialog {
  padding: 0;
}/*
Prevent resizing textareas horizontally by default.
*/textarea {
  resize: vertical;
}/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}/*
Set the default cursor for buttons.
*/button,
[role="button"] {
  cursor: pointer;
}/*
Make sure disabled buttons don't get the pointer cursor.
*/:disabled {
  cursor: default;
}/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/img,
video {
  max-width: 100%;
  height: auto;
}/* Make elements with the HTML hidden attribute stay hidden by default */[hidden] {
  display: none;
}[type='text'],input:where(:not([type])),[type='email'],[type='url'],[type='password'],[type='number'],[type='date'],[type='datetime-local'],[type='month'],[type='search'],[type='tel'],[type='time'],[type='week'],[multiple],textarea,select{
  appearance: none;
  background-color: #fff;
  border-color: #6b7280;
  border-width: 1px;
  border-radius: 0px;
  padding-top: 0.5rem;
  padding-right: 0.75rem;
  padding-bottom: 0.5rem;
  padding-left: 0.75rem;
  font-size: 1rem;
  line-height: 1.5rem;
  --tw-shadow: 0 0 #0000;
}[type='text']:focus, input:where(:not([type])):focus, [type='email']:focus, [type='url']:focus, [type='password']:focus, [type='number']:focus, [type='date']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='week']:focus, [multiple]:focus, textarea:focus, select:focus{
  outline: 2px solid transparent;
  outline-offset: 2px;
  --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: #2563eb;
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  border-color: #2563eb;
}input::placeholder,textarea::placeholder{
  color: #6b7280;
  opacity: 1;
}::-webkit-datetime-edit-fields-wrapper{
  padding: 0;
}::-webkit-date-and-time-value{
  min-height: 1.5em;
  text-align: inherit;
}::-webkit-datetime-edit{
  display: inline-flex;
}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{
  padding-top: 0;
  padding-bottom: 0;
}select{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
  background-position: right 0.5rem center;
  background-repeat: no-repeat;
  background-size: 1.5em 1.5em;
  padding-right: 2.5rem;
  print-color-adjust: exact;
}[multiple],[size]:where(select:not([size="1"])){
  background-image: initial;
  background-position: initial;
  background-repeat: unset;
  background-size: initial;
  padding-right: 0.75rem;
  print-color-adjust: unset;
}[type='checkbox'],[type='radio']{
  appearance: none;
  padding: 0;
  print-color-adjust: exact;
  display: inline-block;
  vertical-align: middle;
  background-origin: border-box;
  user-select: none;
  flex-shrink: 0;
  height: 1rem;
  width: 1rem;
  color: #2563eb;
  background-color: #fff;
  border-color: #6b7280;
  border-width: 1px;
  --tw-shadow: 0 0 #0000;
}[type='checkbox']{
  border-radius: 0px;
}[type='radio']{
  border-radius: 100%;
}[type='checkbox']:focus,[type='radio']:focus{
  outline: 2px solid transparent;
  outline-offset: 2px;
  --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
  --tw-ring-offset-width: 2px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: #2563eb;
  --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
  --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
  box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
}[type='checkbox']:checked,[type='radio']:checked{
  border-color: transparent;
  background-color: currentColor;
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}[type='checkbox']:checked{
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e");
}@media (forced-colors: active) {[type='checkbox']:checked{
    appearance: auto;
  }
}[type='radio']:checked{
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e");
}@media (forced-colors: active) {[type='radio']:checked{
    appearance: auto;
  }
}[type='checkbox']:checked:hover,[type='checkbox']:checked:focus,[type='radio']:checked:hover,[type='radio']:checked:focus{
  border-color: transparent;
  background-color: currentColor;
}[type='checkbox']:indeterminate{
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");
  border-color: transparent;
  background-color: currentColor;
  background-size: 100% 100%;
  background-position: center;
  background-repeat: no-repeat;
}@media (forced-colors: active) {[type='checkbox']:indeterminate{
    appearance: auto;
  }
}[type='checkbox']:indeterminate:hover,[type='checkbox']:indeterminate:focus{
  border-color: transparent;
  background-color: currentColor;
}[type='file']{
  background: unset;
  border-color: inherit;
  border-width: 0;
  border-radius: 0;
  padding: 0;
  font-size: unset;
  line-height: inherit;
}[type='file']:focus{
  outline: 1px solid ButtonText;
  outline: 1px auto -webkit-focus-ring-color;
}*, ::before, ::after{
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
}::backdrop{
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
}@font-face {
  font-family: "BW Gradual";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/BwGradual-Bold-01534a6e248acb5f3a6649caaf8dad184bbfa188.woff2") format("woff2"),
    url("/assets/BwGradual-Bold-63d1be99774919c3ce7c5c7840e8b05263ceab6a.woff") format("woff");
}@font-face {
  font-family: "BW Gradual";
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/BwGradual-BoldItalic-f92ddd7f3b1ee9e7db28d190a7562e5c04529c07.woff2") format("woff2"),
    url("/assets/BwGradual-BoldItalic-3029b072e9b4bad4951be44f36d959b18d237907.woff") format("woff");
}@font-face {
  font-family: "BW Gradual";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/BwGradual-Medium-514d1e846aefc95f2115f242e11a0e49366d7fa2.woff2") format("woff2"),
    url("/assets/BwGradual-Medium-5e76188851f6d5bb2cbde8505719c37966ab9f60.woff") format("woff");
}@font-face {
  font-family: "BW Gradual";
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/BwGradual-MediumItalic-3f68eb2b7d22857f0d78a7d3eaa915e057b4acf9.woff2") format("woff2"),
    url("/assets/BwGradual-MediumItalic-6d7f3616463943d203e5c63283a6b9f346b3d633.woff") format("woff");
}:root {
  --color: hsla(0, 0%, 0%, 1);
  --color-light: hsla(0, 0%, 38%, 1);
  --accent-color: hsla(0, 0%, 100%, 1);
  --border-color: hsla(0, 0%, 85%, 1);

  /* Focus states */
  --outline-width: 0.125rem;
  --outline-color: var(--color);
  --outline-offset: var(--outline-width);

  /* Containers */
  --container-padding-inline: clamp(1rem, 0.376rem + 2.7132vw, 2.75rem);
  --container-inline-size: 84.5rem;

  /* Nav bar */
  --nav-bar-inline-padding: clamp(0.5rem, -0.124rem + 2.7132vw, 2.25rem);
  --nav-bar-height: clamp(2.75rem, 2.527rem + 0.9690vw, 3.375rem);

  /* Solution Filters */
  --solution-filters-padding: min(10.5%, 2.25rem);

  /* Root variables from IOI's website */
  --white: hsla(0, 0%, 100%, 1);
  --white2: hsla(0, 0%, 97%, 1);
  --grey: hsla(0, 0%, 38%, 1);
  --grey2: hsla(0, 0%, 41%, 1);
  --black: hsla(0, 0%, 0%, 1);
  --yellow: hsla(51, 100%, 55%, 1);
  --yellow2: hsla(45, 94%, 80%, 1);
  --green: hsla(162, 78%, 73%, 1);
  --green2: hsla(155, 92%, 85%, 1);
  --blue: hsla(208, 100%, 84%, 1);
  --orange: hsla(19, 100%, 82%, 1);
  --orange2: hsla(36, 100%, 82%, 1);

  --font1: Inter, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --font2: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";

  --vhs: 3rem;
}* {
  border-color: var(--border-color);
}@media (prefers-reduced-motion: no-preference) {html {
    scroll-behavior: smooth
}
  }body {
  background-color: hsla(0, 0%, 97%, 1);
  color: var(--color);
}:is(
    [href],
    button,
    input,
    textarea,
    summary,
    select,
    [tabindex],
    [draggable],
    area,
    object,
    iframe,
    .m-button
  ) {
  line-height: inherit;
  font-size: inherit;
  font-family: inherit;
}:is(
    [href],
    button,
    input,
    textarea,
    summary,
    select,
    [tabindex],
    [draggable],
    area,
    object,
    iframe,
    .m-button
  ):focus {
    outline: 0;
    box-shadow: none;
  }:is(
    [href],
    button,
    input,
    textarea,
    summary,
    select,
    [tabindex],
    [draggable],
    area,
    object,
    iframe,
    .m-button
  ):focus-visible {
    outline: var(--outline-width) solid var(--outline-color);
    outline-offset: var(--outline-offset, var(--outline-width));
  }.bg-black :is(
    [href],
    button,
    input,
    textarea,
    summary,
    select,
    [tabindex],
    [draggable],
    area,
    object,
    iframe,
    .m-button
  ) {
    --outline-color: hsla(0, 0%, 100%, 1);
  }.bg-brand-mint :is(
    [href],
    button,
    input,
    textarea,
    summary,
    select,
    [tabindex],
    [draggable],
    area,
    object,
    iframe,
    .m-button
  ) {
    --outline-color: hsla(0, 0%, 0%, 1);
  }a:not(class):hover {
  text-decoration-line: underline;
}button:not([class]),
input[type="submit"]:not([class]),
.m-button {
  display: inline-flex;
  justify-content: space-between;
  gap: 0.6875rem;
  padding-block: 0.875rem;
  padding-inline: 1.5rem;
  color: var(--color);
  background-color: hsla(0, 0%, 92%, 1);
}button:not([class]):not(:disabled, [aria-disabled]), input[type="submit"]:not([class]):not(:disabled, [aria-disabled]), .m-button:not(:disabled, [aria-disabled]) {
    cursor: pointer;
  }button:not([class]):not(:disabled, [aria-disabled]):hover, input[type="submit"]:not([class]):not(:disabled, [aria-disabled]):hover, .m-button:not(:disabled, [aria-disabled]):hover {
      background-color: hsla(0, 0%, 85%, 1);
    }button:not([class]):not(:disabled, [aria-disabled]).bg-black:hover, input[type="submit"]:not([class]):not(:disabled, [aria-disabled]).bg-black:hover, .m-button:not(:disabled, [aria-disabled]).bg-black:hover {
      background-color: hsla(0, 0%, 38%, 1);
    }button:not([class]):not(:disabled, [aria-disabled]).bg-brand-mint:hover, input[type="submit"]:not([class]):not(:disabled, [aria-disabled]).bg-brand-mint:hover, .m-button:not(:disabled, [aria-disabled]).bg-brand-mint:hover {
      background-color: hsla(162, 78%, 60%, 1);
    }button:not([class]):hover, input[type="submit"]:not([class]):hover, .m-button:hover {
    text-decoration: none;
  }button:not([class]) > svg, input[type="submit"]:not([class]) > svg, .m-button > svg {
    flex: 0 0 auto;
  }button:not([class]) > svg:last-child, input[type="submit"]:not([class]) > svg:last-child, .m-button > svg:last-child {
      margin-inline-end: -0.25rem;
    }button:not([class]) > svg:first-child, input[type="submit"]:not([class]) > svg:first-child, .m-button > svg:first-child {
      margin-inline-start: -0.25rem;
    }:is([type="search"], select, textarea, [type="search"]){
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  background-color: var(--accent-color);
  border: transparent;
}:is(select) {
  background-image: url("/assets/icons/16/Disclosure-Down-3d150df2a40ce32c9183866aa8afaed956a7abc3.svg");
  background-repeat: no-repeat;
  background-size: 1rem;
}:is(input[type="checkbox"], input[type="radio"]) {
  accent-color: hsla(0, 0%, 100%, 1);
}:is(input[type="checkbox"], input[type="radio"]):focus {
    outline: 0;
    box-shadow: none;
  }:is(input[type="checkbox"], input[type="radio"]):focus-visible {
    outline: var(--outline-width) solid var(--outline-color);
    outline-offset: var(--outline-offset, var(--outline-width));
  }svg {
  fill: currentColor;
}hr {
  border-top: 0.125rem solid var(--border-color);
  margin-block: 2.0625rem;
}html{
  font-family: Inter, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  text-rendering: geometricPrecision;
  text-decoration-thickness: from-font;
  text-underline-position: from-font;
}body{
  font-size: clamp(1rem, 0.978rem + 0.0969vw, 1.0625rem);
  line-height: 1.625rem;
  letter-spacing: -0.0156rem;
  font-weight: 500;
}:is(h1, h2, h3, h4, h5, h6){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}h1{
  font-size: clamp(2rem, 1.688rem + 1.3566vw, 2.875rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}:is(h1,
    .text-h2,
    .text-h3,
    .text-h4,
    .text-h5,
    .text-h6,
    .text-label,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}h2{
  font-size: clamp(2rem, 1.911rem + 0.3876vw, 2.25rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}:is(
    .text-h1,h2,
    .text-h3,
    .text-h4,
    .text-h5,
    .text-h6,
    .text-label,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}h3{
  font-size: clamp(1.5rem, 1.455rem + 0.1938vw, 1.625rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}:is(
    .text-h1,
    .text-h2,h3,
    .text-h4,
    .text-h5,
    .text-h6,
    .text-label,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}h4{
  font-size: clamp(1.25rem, 1.161rem + 0.3876vw, 1.5rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}:is(
    .text-h1,
    .text-h2,
    .text-h3,h4,
    .text-h5,
    .text-h6,
    .text-label,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}h5{
  font-size: clamp(1.0625rem, 0.996rem + 0.2907vw, 1.25rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}:is(
    .text-h1,
    .text-h2,
    .text-h3,
    .text-h4,h5,
    .text-h6,
    .text-label,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}h6{
  font-size: clamp(1rem, 0.955rem + 0.1938vw, 1.125rem);
  line-height: normal;
  letter-spacing: -0.0187rem;
  font-weight: 700;
}:is(
    .text-h1,
    .text-h2,
    .text-h3,
    .text-h4,
    .text-h5,h6,
    .text-label,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}button,
input[type="submit"] {
  font-family: inherit;
}body:has(dialog[open]) {
    position: absolute;
    inline-size: 100%;
    overflow: hidden;
  }.footer-wrap {
    align-items: flex-start;
    display: flex;
    justify-content: space-between;
    padding-top: 10vh;
    padding-bottom: 9vh;
  }@media print {
  .footer-wrap {
      --color: hsla(0, 0%, 0%, 1);

      padding-block: 2.5rem
  }
    }.footer-wrap h3 {
      margin-top: 1.75rem;
      margin-bottom: 3rem;
      /* From IOI site */
      font-size: 1.17em;
    }.footer-wrap a {
      font-size: 0.9rem;
    }.footer-wrap ul {
      list-style: none;
      margin: 0;
      padding: 0;
    }.footer-wrap ul li {
        padding: 0;
        line-height: 1.75;
      }/* Footer navigation */.footer-nav {
    min-width: 40%;
  }@media print {
  .footer-nav {
      display: none
  }
    }.footer-nav ul {
      columns: 2;
    }/* Footer social links */@media print {
  .footer-social {
      display: none
  }
    }.footer-social li a {
    display: block;
    border-bottom: 1px solid var(--grey);
    padding-bottom: 0.5rem;
    margin-bottom: 0.5rem;
    font-weight: bold;
    font-size: 1rem;
  }.footer-social li a:hover {
      color: var(--yellow);
      text-decoration: none;
    }/* Footer copyright text */.footer-description,
  .footer-copyright {
    font-size: 13px;
    max-width: 20rem;
  }.footer-copyright {
    margin: var(--vhs) 0 1rem;
    color: var(--color-light);
  }.footer-wrap,
  .footer-data {
    box-sizing: border-box;
  }.footer-logo,
  .footer-description,
  .footer-icons {
    width: 21.875rem;
    max-width: 88vw;
  }.footer-logo img {
    max-width: 12.5rem;
  }@media screen and (max-width: 989px) {
    .footer-wrap {
      flex-wrap: wrap;
    }
    .footer-social,
    .footer-nav,
    .footer-data {
      width: 100%;
    }
    .footer-wrap h3 {
      border-top: 1px solid var(--grey);
      margin-bottom: 1rem;
      padding-top: 2rem;
    }
  }/* Arrow icon */.arrow::after {
    content: "→";
    float: right;
    font-weight: bold;
    font-size: 1rem;
    margin-left: 1rem;
  }/* Logo */#home-link {
    margin-right: 8vw;
    flex: 0 0 auto;
  }#home-link img {
      width: 12.5rem;
      padding-top: 1rem;
      padding-right: var(--header-link-padding);
      padding-bottom: 0.25rem;
    }.header-section {
    position: relative;
    background-color: var(--white);
    z-index: 999;
  }.header-nav {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    color: var(--black);
  }@media screen and (max-width: 72.8125rem) {

  .header-nav {
      justify-content: space-between;
      color: var(--white)
  }
    }.header-nav-list {
    display: flex;
    position: relative;
    list-style: none;
    padding: 0;
    margin: 0;
    flex: 1 1 auto;
  }@media screen and (max-width: 72.8125rem) {

  .header-nav-list {
      display: none;
      position: absolute;
      top: 58px;
      right: var(--container-padding-inline);
      min-width: 250px;
      background-color: black;
      max-height: calc(100vh - var(--nav-height));
      overflow: auto
  }
    }@media print {

  .header-nav-list {
      display: none
  }
    }/* Top level nav item */.header-nav-item {
    position: relative;
    display: flex;
    font-size: 1rem;
  }.header-nav-item > a,
    .header-nav-item > .spacer {
      height: var(--nav-height);
    }.header-nav-item > .spacer + a {
      position: absolute;
      white-space: nowrap;
    }.header-nav-item .spacer {
      font-weight: bold;
      overflow: hidden;
      visibility: hidden;
      white-space: nowrap;
    }.header-nav-item a,
    .header-nav-item > .spacer {
      display: flex;
      align-items: center;
      min-width: 100%;
      text-align: center;
      padding: 0 var(--header-link-padding);
      cursor: pointer;
    }.header-nav-item a:hover, .header-nav-item > .spacer:hover {
        text-decoration: none;
      }.header-nav-item a {
      --outline-offset: calc(var(--outline-width) * -1);
    }@media screen and (max-width: 72.8125rem) {
  .header-nav-item {
      flex-direction: column
  }

      .header-nav-item > a {
        font-size: 0.9rem;
      }

      .header-nav-item > a:hover {
        background-color: var(--yellow);
        color: var(--black);
        font-weight: bold;
      }

      .header-nav-item > a,
      .header-nav-item > .spacer {
        height: auto;
      }

      .header-nav-item > .spacer + a {
        position: relative;
        padding: 0.5rem 1rem;
      }

      .header-nav-item .spacer {
        display: none;
      }
    }/* Top level nav item, not last button */@media screen and (min-width: 72.8125rem) {
      .header-nav-item:not(:last-of-type):hover {
        background-color: var(--black);
      }

      .header-nav-item:not(:last-of-type):hover > a {
        color: var(--white);
        font-weight: bold;
        cursor: pointer;
      }

      .header-nav-item:not(:last-of-type):not(:hover) > a[aria-current="page"] {
        background-color: hsla(162, 78%, 73%, 1);
        font-weight: bold;
      }
    }/* Top level nav item, last button */.header-nav-item:last-of-type a {
      background-color: var(--yellow);
      color: var(--black);
      min-width: auto;
    }@media screen and (min-width: 72.8125rem) {
  .header-nav-item:last-of-type {
      padding-left: var(--header-link-padding);
      margin-left: auto
  }

      .header-nav-item:last-of-type > a {
        --outline-offset: var(--outline-width);
        --outline-color: var(--black);

        background-color: var(--black);
        border-radius: var(--radius);
        height: var(--nav-item-height);
        align-self: center;
        color: var(--white);
        font-weight: bold;
      }

        .header-nav-item:last-of-type > a:hover {
          background-color: var(--yellow);
          color: var(--black);
        }

      .header-nav-item:last-of-type .spacer {
        min-width: auto;
      }
    }/* Dropdown lists */.header-nav-item ul .spacer {
      display: none;
    }.header-nav-item ul a {
      height: var(--nav-item-height);
      text-wrap: nowrap;
      font-weight: normal;
      font-size: 0.9rem;
      color: var(--white);
      width: 100%;
    }.header-nav-item ul a:hover {
        color: var(--black);
        background-color: var(--white);
        font-weight: bold;
      }@media screen and (min-width: 72.8125rem) {
  .header-nav-item ul {
      display: none;
      position: absolute;
      flex-wrap: wrap;
      background-color: var(--black);
      top: var(--nav-height);
      min-width: 14rem;
      overflow-x: hidden
  }
    }@media screen and (max-width: 72.8125rem) {
      .header-nav-item ul a {
        padding: 0.5rem 0 0.5rem 1.5rem;
        font-size: 0.9rem;
      }

        .header-nav-item ul a:hover {
          background-color: var(--yellow);
        }
    }.header-nav-item:hover ul {
    display: block;
  }/* Header toggle & checkbox */.header-checkbox{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}.header-checkbox:checked {
      border: 5px solid magenta;
    }.header-toggle {
    display: none;
    position: relative;
    z-index: 99;
    overflow: visible;
    width: 48px;
    height: 40px;
    margin: 0;
    padding: 0 8px 2px;
    cursor: pointer;
    opacity: 1;
    border: none;
    outline: none;
    background-color: var(--black);
  }.header-toggle > span {
      position: relative;
      display: block;
      width: 100%;
      top: 50%;
    }@media screen and (max-width: 72.8125rem) {

  .header-toggle {
      display: block
  }
    }.bar {
    position: absolute;
    display: block;
    width: 100%;
    height: 3px;
    content: "";
    background-color: var(--white);
    transition: transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1),
      top 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) 0.2s;
  }.bar:nth-child(1) {
      top: -10px;
    }.bar:nth-child(2) {
      top: 10px;
    }@media screen and (max-width: 72.8125rem) {
      .header-checkbox:checked + .header-toggle span .bar {
        transition: transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
      }

        .header-checkbox:checked + .header-toggle span .bar:nth-child(1),
        .header-checkbox:checked + .header-toggle span .bar:nth-child(2) {
          top: 0;
          transform: rotate(45deg);
        }

        .header-checkbox:checked + .header-toggle span .bar:nth-child(3) {
          transform: rotate(-45deg);
        }

      .header-checkbox:checked ~ .header-nav-list {
        display: inline-block;
      }
    }.m-badge {
  --_badge-padding-block: 0.8125rem;
  --_badge-padding-inline: 1rem;

  display: flex;
  align-items: stretch;
  gap: 1rem;
  overflow: hidden;
  padding-block: var(--_badge-padding-block);
  padding-inline: var(--_badge-padding-inline);
  background-color: hsla(0, 0%, 97%, 1);
  border-radius: 0.375rem;
  font-size: clamp(0.875rem, 0.853rem + 0.0969vw, 0.9375rem);
  line-height: normal;
  letter-spacing: 0rem;
  font-weight: 500;
}.m-badge .solution-location-icon {
    block-size: 1rem;
  }.m-badge{
  font-weight: 600;
}@media print {.m-badge {
    border: 1px solid hsla(0, 0%, 41%, 1)
}
  }.m-badge:has(span) {
    padding: 0;
    gap: 0;
  }.m-badge:has(span) > span {
      padding-block: var(--_badge-padding-block);
      padding-inline: var(--_badge-padding-inline);
    }.m-badge:has(span) > span:has(img) {
      padding-inline: calc(var(--_badge-padding-inline) - 0.25rem);
    }.m-badge--lg {
    --_badge-padding-block: 0.8rem;
    --_badge-padding-inline: 1.5rem;
    font-size: clamp(1rem, 0.978rem + 0.0969vw, 1.0625rem);
    line-height: 1.625rem;
    letter-spacing: -0.0156rem;
    font-weight: 600;
  }.m-badge--sm {
    --_badge-padding-block: 0.4375rem;
    --_badge-padding-inline: 0.875rem;

    display: inline-flex;
    gap: 0.625rem;
    font-size: clamp(0.8125rem, 0.790rem + 0.0969vw, 0.875rem);
    line-height: normal;
    letter-spacing: 0rem;
    font-weight: 600;
  }.m-badge--sm img {
      margin-inline-start: -0.25rem;
      block-size: 1rem;
    }.m-badge--fit-to-content {
    inline-size: fit-content;
  }.m-badge--white {
    --_badge-padding-block: clamp(0.75rem, 0.661rem + 0.3876vw, 1rem);
    --_badge-padding-inline: clamp(1.25rem, 1.161rem + 0.3876vw, 1.5rem);
    background-color: hsla(0, 0%, 100%, 1);
  --color: hsla(0, 0%, 0%, 1);
  border-radius: 0.75rem;
  font-size: 1rem;
  line-height: 1.1875rem;
  letter-spacing: 0rem;
  font-weight: 700;
  }:is(
    .text-h1,
    .text-h2,
    .text-h3,
    .text-h4,
    .text-h5,
    .text-h6,.m-badge--white,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}.m-badge--neutral-20 {
    --_badge-padding-block: 0.475rem;
    --_badge-padding-inline: 0.925rem;
    background-color: hsla(0, 0%, 92%, 1);
  --border-color: hsla(0, 0%, 41%, 1);
    font-size: 0.875rem;
  }/* See base/_appearance for base button styles */.m-button {
  display: flex;
  align-items: center;
  border-radius: 12.5rem;
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  font-size: 1rem;
  line-height: 1.1875rem;
  letter-spacing: 0rem;
  font-weight: 700;
}:is(
    .text-h1,
    .text-h2,
    .text-h3,
    .text-h4,
    .text-h5,
    .text-h6,.m-button,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}@media print {.m-button {
    border: 2px solid hsla(0, 0%, 41%, 1)
}
  }.m-button--center {
    justify-content: center;
  }.m-button--lg {
    gap: 1rem;
    padding-block: 1.0625rem;
    padding-inline: 1.75rem;
  }.m-button--lg > svg,
    .m-button--lg > img {
      block-size: 1.5rem;
      margin-block: -0.125rem;
    }.m-button--sm {
    gap: 0.6875rem;
    padding-block: 0.6563rem;
    padding-inline: 1.25rem;
    font-family: Inter, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    font-size: clamp(0.875rem, 0.853rem + 0.0969vw, 0.9375rem);
    line-height: normal;
    letter-spacing: 0rem;
    font-weight: 500;
  }.m-button--sm .solution-location-icon {
    block-size: 1rem;
  }.m-button--sm{
  font-weight: 600;
}.m-button--sm > svg,
    .m-button--sm > img {
      block-size: 1rem;
    }.m-button--fit-to-content {
    inline-size: fit-content;
  }.m-button > svg,
  .m-button > img {
    flex: 0 0 auto;
  }.m-card {
  --default-card-inner-gap: clamp(1rem, 0.955rem + 0.1938vw, 1.125rem);
  --rte-li-margin-block-start: 0.5em;

  display: flex;
  flex-direction: column;
  background-color: hsla(0, 0%, 100%, 1);
  padding: clamp(1.25rem, 1.161rem + 0.3876vw, 1.5rem);
  border-radius: 1.25rem;
}.m-card > * + * {
    margin-block-start: var(--card-inner-gap, var(--default-card-inner-gap));
  }.m-checkbox{
  font-size: clamp(0.875rem, 0.853rem + 0.0969vw, 0.9375rem);
  line-height: normal;
  letter-spacing: 0rem;
  font-weight: 500;
}.m-checkbox .solution-location-icon {
    block-size: 1rem;
  }.m-checkbox {
  cursor: pointer;
}.m-checkbox input{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}.m-checkbox input:focus,
    .m-checkbox input:focus-visible {
      outline: 0;
    }.m-checkbox input:checked + span::before {
      background-image: url("/assets/icons/20/Checkbox-Checked-a816042d02e0f1ac2269461c1a7c4f988ce1f5ce.svg");
    }.m-checkbox input:focus-visible + span::before {
      --outline-offset: 0;

      outline: var(--outline-width) solid var(--outline-color);

      outline-offset: var(--outline-offset, var(--outline-width));
    }.m-checkbox input + span {
    display: flex;
    gap: 0.625rem;
  }.m-checkbox input + span::before {
      content: "";
      flex: 0 0 auto;
      display: inline-block;
      block-size: 1.25rem;
      inline-size: 1.25rem;
      border-radius: 0.3125rem;
      background-image: url("/assets/icons/20/Checkbox-Unchecked-74978f3d3de586b68b1ea1504ee70ebd5ef7424a.svg");
      background-repeat: no-repeat;
    }.m-solution-card {
  position: relative;
  display: flex;
  flex-direction: column;
  block-size: 100%;
  background-color: hsla(0, 0%, 100%, 1);
  border-radius: var(--_card-border-radius);
  overflow: hidden;
  border-radius: 1.5rem;
}.m-solution-card:has(.comparison-toggle[aria-pressed="true"]) {
    outline: 0.25rem solid hsla(162, 78%, 73%, 1);
    outline-offset: -0.25rem;
  }@media print {.m-solution-card {
    break-inside: avoid;
    border: 1px solid hsla(0, 0%, 41%, 1)
}
  }.m-solution-card > * {
    padding-inline: clamp(1rem, 0.554rem + 1.9380vw, 2.25rem);
  }@media print {.m-solution-card > * {
      padding-inline: 16px
  }
    }.m-solution-card > *:last-child {
      padding-block-end: clamp(1.25rem, 0.983rem + 1.1628vw, 2rem);
    }.m-solution-card > * + div {
      padding-block-start: clamp(1rem, 0.822rem + 0.7752vw, 1.5rem);
    }.m-solution-card__close {
    position: absolute;
    inset-block-start: 1rem;
    inset-inline-end: 1rem;
  }.m-solution-card__close:focus-visible {
      outline: var(--outline-width) solid var(--outline-color);
      outline-offset: var(--outline-offset, var(--outline-width));
    }.m-solution-card__header {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-block-size: clamp(6.25rem, 5.804rem + 1.9380vw, 7.5rem);
    padding-block-end: clamp(1rem, 0.911rem + 0.3876vw, 1.25rem);
    padding-block-start: clamp(2rem, 1.822rem + 0.7752vw, 2.5rem);
    background-color: hsla(162, 78%, 73%, 1);
  }.m-solution-card__header :is(
    [href],
    button,
    input,
    textarea,
    summary,
    select,
    [tabindex],
    [draggable],
    area,
    object,
    iframe,
    .m-button
  ) {
    --outline-color: hsla(0, 0%, 0%, 1);
  }button:not([class]):not(:disabled, [aria-disabled]).m-solution-card__header:hover, input[type="submit"]:not([class]):not(:disabled, [aria-disabled]).m-solution-card__header:hover, .m-button:not(:disabled, [aria-disabled]).m-solution-card__header:hover {
      background-color: hsla(162, 78%, 60%, 1);
    }@media print {.m-solution-card__header {
      padding-block-start: clamp(1rem, 0.911rem + 0.3876vw, 1.25rem)
  }
    }.m-solution-card__header > h3{
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}.m-solution-card__header-link {
    --outline-offset: calc(-1 * var(--outline-width));
    
    text-decoration-line: underline;
    text-decoration-color: transparent;
    transition-property: text-decoration-color;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
  }.m-solution-card__header-link:hover {
      text-decoration-color: currentColor;
    }.m-solution-card__badges {
    flex-grow: 1;
  }.m-solution-card__badges > * + * {
      margin-block-start: 1rem;
    }.m-solution-card__footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 0.75rem;
    margin-block-start: 1.375rem;
    padding-block-start: 1.75rem;
  }.m-table{
  font-size: clamp(0.875rem, 0.853rem + 0.0969vw, 0.9375rem);
  line-height: normal;
  letter-spacing: 0rem;
  font-weight: 500;
}.m-table .solution-location-icon {
    block-size: 1rem;
  }.m-table__row {
    display: grid;
    grid-template-columns: repeat(
      var(--table-columns, auto-fit),
      minmax(var(--table-column-min, 7.5rem), 1fr)
    );
  }@media print {.m-table__row {
      --table-column-min: 25%
  }
    }.m-table__columnheader,
  .m-table__rowheader,
  .m-table__cell {
    padding-inline-end: 1rem;
    padding-block: 1.25rem;
  }.m-table__columnheader {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    border-bottom: 0.125rem solid hsla(0, 0%, 0%, 1);
  }.m-table__rowheader,
  .m-table__cell {
    border-bottom-width: 1px;
  }@media (max-width: 64rem) {.m-table__rowheader,
  .m-table__columnheader:first-child {
      grid-column: 1 / -1;
      padding-block-end: 0.75rem
  }
    }.m-table__cell {
    --rte-li-margin-block-start: 0.375em;
  }@media (max-width: 64rem) {.m-table__cell {
      border-bottom-width: 0
  }
    }.m-table .m-comparison-bar-item {
    margin-inline: calc(var(--_table-column-gap) * -1);
  }.m-nav-bar {
  --outline-offset: calc(var(--outline-width) * -1);

  overflow-x: auto;
  white-space: nowrap;
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
  font-size: clamp(0.875rem, 0.853rem + 0.0969vw, 0.9375rem);
  line-height: normal;
  letter-spacing: 0rem;
  font-weight: 500;
}.m-nav-bar .solution-location-icon {
    block-size: 1rem;
  }@media print {.m-nav-bar {
    display: none
}
  }.m-nav-bar:not([class*="bg-"]) {
    /* Default background color */
    background-color: hsla(0, 0%, 92%, 1);
  --border-color: hsla(0, 0%, 41%, 1);
  }@media screen and (min-width: 72.8125rem) {.m-nav-bar--centered .m-nav-bar__list {
      justify-content: center
  }
    }.m-nav-bar__list {
    display: flex;
  }.m-nav-bar__list li:first-child {
      margin-inline-start: calc(var(--nav-bar-inline-padding) * -1);
    }.m-nav-bar__link {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    block-size: var(--nav-bar-height);
    padding-inline: var(--nav-bar-inline-padding);
  }.m-nav-bar__link:hover{
  background-color: hsla(0, 0%, 0%, 1);
}.m-nav-bar__link:hover :is(
    [href],
    button,
    input,
    textarea,
    summary,
    select,
    [tabindex],
    [draggable],
    area,
    object,
    iframe,
    .m-button
  ) {
    --outline-color: hsla(0, 0%, 100%, 1);
  }button:not([class]):not(:disabled, [aria-disabled]).m-nav-bar__link:hover:hover, input[type="submit"]:not([class]):not(:disabled, [aria-disabled]).m-nav-bar__link:hover:hover, .m-button:not(:disabled, [aria-disabled]).m-nav-bar__link:hover:hover {
      background-color: hsla(0, 0%, 38%, 1);
    }.m-nav-bar__link:hover {
  --color: hsla(0, 0%, 97%, 1);
  --color-light: hsla(0, 0%, 75%, 1);
  color: hsla(0, 0%, 100%, 1);
  font-weight: 700;
      text-decoration: none;
}/* Create a pseudo element to prevent layout shift on hover
    https://css-tricks.com/bold-on-hover-without-the-layout-shift/ */.m-nav-bar__link::after {
      content: attr(data-text);
      content: attr(data-text) / "";
      height: 0;
      visibility: hidden;
      overflow: hidden;
      user-select: none;
      pointer-events: none;
      font-weight: 700;
    }@media speech {.m-nav-bar__link::after {
        display: none
    }
      }.m-nav-bar__link[aria-current="page"],
    .m-nav-bar__link[data-active="true"]{
  font-weight: 700;
}.sr-only{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}.absolute{
  position: absolute;
}.relative{
  position: relative;
}.sticky{
  position: sticky;
}.bottom-0{
  bottom: 0px;
}.top-0{
  top: 0px;
}.z-messages{
  z-index: 60;
}.mx-auto{
  margin-left: auto;
  margin-right: auto;
}.-ms-1{
  margin-inline-start: -0.25rem;
}.mb-10{
  margin-bottom: 2.5rem;
}.mb-4{
  margin-bottom: 1rem;
}.mb-8{
  margin-bottom: 2rem;
}.me-auto{
  margin-inline-end: auto;
}.mt-6{
  margin-top: 1.5rem;
}.mt-\[0\.75em\]{
  margin-top: 0.75em;
}.mt-\[3\.75rem\]{
  margin-top: 3.75rem;
}.line-clamp-2{
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}.line-clamp-4{
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}.line-clamp-6{
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 6;
}.block{
  display: block;
}.inline{
  display: inline;
}.flex{
  display: flex;
}.table{
  display: table;
}.grid{
  display: grid;
}.hidden{
  display: none;
}.h-6{
  height: 1.5rem;
}.h-full{
  height: 100%;
}.w-6{
  width: 1.5rem;
}.w-fit{
  width: fit-content;
}.w-full{
  width: 100%;
}.max-w-\[44rem\]{
  max-width: 44rem;
}.max-w-base{
  max-width: 84.5rem;
}.max-w-narrow{
  max-width: 74rem;
}.max-w-screen-xl{
  max-width: 87.5rem;
}.max-w-text{
  max-width: 52.1875rem;
}.flex-grow{
  flex-grow: 1;
}.grow{
  flex-grow: 1;
}.grid-cols-1{
  grid-template-columns: repeat(1, minmax(0, 1fr));
}.grid-cols-\[auto_1fr\]{
  grid-template-columns: auto 1fr;
}.flex-col{
  flex-direction: column;
}.flex-wrap{
  flex-wrap: wrap;
}.items-start{
  align-items: flex-start;
}.items-center{
  align-items: center;
}.justify-center{
  justify-content: center;
}.justify-between{
  justify-content: space-between;
}.gap-1{
  gap: 0.25rem;
}.gap-1\.5{
  gap: 0.375rem;
}.gap-2{
  gap: 0.5rem;
}.gap-3{
  gap: 0.75rem;
}.gap-4{
  gap: 1rem;
}.gap-6{
  gap: 1.5rem;
}.gap-\[0\.625rem\]{
  gap: 0.625rem;
}.gap-y-2{
  row-gap: 0.5rem;
}.space-y-\[0\.625rem\] > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(0.625rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.625rem * var(--tw-space-y-reverse));
}.truncate{
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}.text-balance{
  text-wrap: balance;
}.rounded-full{
  border-radius: 25rem;
}.rounded-lg{
  border-radius: 1.25rem;
}.rounded-md{
  border-radius: 1rem;
}.rounded-xs{
  border-radius: 0.375rem;
}.border{
  border-width: 1px;
}.border-y{
  border-top-width: 1px;
  border-bottom-width: 1px;
}.border-b{
  border-bottom-width: 1px;
}.border-t{
  border-top-width: 1px;
}.border-neutral-40{
  border-color: hsla(0, 0%, 75%, 1);
}.bg-black{
  background-color: hsla(0, 0%, 0%, 1);
}.bg-brand-blue{
  background-color: hsla(208, 100%, 84%, 1);
}.bg-brand-blue-tint{
  background-color: hsla(208, 100%, 84%, .7);
}.bg-brand-mint{
  background-color: hsla(162, 78%, 73%, 1);
}.bg-brand-mint-tint{
  background-color: hsla(155, 92%, 85%, 1);
}.bg-brand-mint\/25{
  background-color: hsla(162, 78%, 73%, 0.25);
}.bg-brand-orange-tint{
  background-color: hsla(36, 100%, 82%, 1);
}.bg-brand-yellow-tint{
  background-color: hsla(45, 94%, 80%, 1);
}.bg-neutral-20{
  background-color: hsla(0, 0%, 92%, 1);
}.bg-neutral-30{
  background-color: hsla(0, 0%, 85%, 1);
}.bg-white{
  background-color: hsla(0, 0%, 100%, 1);
}.fill-current{
  fill: currentColor;
}.p-10{
  padding: 2.5rem;
}.px-3{
  padding-left: 0.75rem;
  padding-right: 0.75rem;
}.px-4{
  padding-left: 1rem;
  padding-right: 1rem;
}.px-6{
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}.px-8{
  padding-left: 2rem;
  padding-right: 2rem;
}.py-2{
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}.py-3{
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}.py-4{
  padding-top: 1rem;
  padding-bottom: 1rem;
}.py-8{
  padding-top: 2rem;
  padding-bottom: 2rem;
}.py-\[2\.0625rem\]{
  padding-top: 2.0625rem;
  padding-bottom: 2.0625rem;
}.pb-10{
  padding-bottom: 2.5rem;
}.pb-3{
  padding-bottom: 0.75rem;
}.pb-4{
  padding-bottom: 1rem;
}.pb-6{
  padding-bottom: 1.5rem;
}.pb-\[7\.5rem\]{
  padding-bottom: 7.5rem;
}.pt-2{
  padding-top: 0.5rem;
}.pt-2\.5{
  padding-top: 0.625rem;
}.pt-3{
  padding-top: 0.75rem;
}.pt-3\.5{
  padding-top: 0.875rem;
}.pt-4{
  padding-top: 1rem;
}.pt-5{
  padding-top: 1.25rem;
}.pt-6{
  padding-top: 1.5rem;
}.pt-8{
  padding-top: 2rem;
}.pt-9{
  padding-top: 2.25rem;
}.pt-\[0\.125rem\]{
  padding-top: 0.125rem;
}.pt-\[1\.625rem\]{
  padding-top: 1.625rem;
}.text-center{
  text-align: center;
}.text-4xl{
  font-size: 2.25rem;
  line-height: 2.5rem;
}.text-base{
  font-size: clamp(1rem, 0.978rem + 0.0969vw, 1.0625rem);
  line-height: 1.625rem;
  letter-spacing: -0.0156rem;
  font-weight: 500;
}.text-h2{
  font-size: clamp(2rem, 1.911rem + 0.3876vw, 2.25rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}.text-h3{
  font-size: clamp(1.5rem, 1.455rem + 0.1938vw, 1.625rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}.text-h4{
  font-size: clamp(1.25rem, 1.161rem + 0.3876vw, 1.5rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}.text-h5{
  font-size: clamp(1.0625rem, 0.996rem + 0.2907vw, 1.25rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}.text-h6{
  font-size: clamp(1rem, 0.955rem + 0.1938vw, 1.125rem);
  line-height: normal;
  letter-spacing: -0.0187rem;
  font-weight: 700;
}.text-label{
  font-size: 1rem;
  line-height: 1.1875rem;
  letter-spacing: 0rem;
  font-weight: 700;
}.text-lg{
  font-size: 1.25rem;
  line-height: normal;
  letter-spacing: 0rem;
  font-weight: 500;
}.text-staff{
  font-size: 3.25rem;
  line-height: 3.5rem;
  font-weight: 500;
}.text-terms{
  font-size: 0.8125rem;
  line-height: normal;
  letter-spacing: 0rem;
  font-weight: 500;
}.text-xl{
  font-size: 1.375rem;
  line-height: normal;
  letter-spacing: 0rem;
  font-weight: 500;
}.text-xs{
  font-size: clamp(0.875rem, 0.853rem + 0.0969vw, 0.9375rem);
  line-height: normal;
  letter-spacing: 0rem;
  font-weight: 500;
}.text-xxs{
  font-size: clamp(0.8125rem, 0.790rem + 0.0969vw, 0.875rem);
  line-height: normal;
  letter-spacing: 0rem;
  font-weight: 500;
}.font-bold{
  font-weight: 700;
}.font-extrabold{
  font-weight: 800;
}.font-light{
  font-weight: 300;
}.font-normal{
  font-weight: 400;
}.font-semibold{
  font-weight: 600;
}.italic{
  font-style: italic;
}.leading-none{
  line-height: 1;
}.tracking-tight{
  letter-spacing: -0.025em;
}.text-\[name\]{
  color: name;
}.text-gray-500{
  --tw-text-opacity: 1;
  color: rgb(107 114 128 / var(--tw-text-opacity));
}.text-gray-900{
  --tw-text-opacity: 1;
  color: rgb(17 24 39 / var(--tw-text-opacity));
}.text-light{
  color: var(--color-light);
}.text-neutral-70{
  color: hsla(0, 0%, 38%, 1);
}.underline{
  text-decoration-line: underline;
}.outline{
  outline-style: solid;
}.\@container{
  container-type: inline-size;
}/* In the interest of time & reduced complexity,
background classes will extend tailwind's 'bg-' pattern. */[class*="bg-"] {
  color: var(--color);
  accent-color: var(--accent-color);
}.bg-white,
[class*="bg-brand-"],
[class*="bg-neutral-"] {
  --color: hsla(0, 0%, 0%, 1);
}.bg-black {
  --color: hsla(0, 0%, 97%, 1);
  --color-light: hsla(0, 0%, 75%, 1);
}.bg-neutral-20 {
  --border-color: hsla(0, 0%, 41%, 1);
}/* A short line rendered after a block or heading */.a-underline::after {
    display: block;
    content: "";
    block-size: 0px;
    inline-size: 5rem;
    margin-block-start: 1.5rem;
    border-bottom: 0.375rem solid var(--color);
  }.a-underline--lt::after {
    inline-size: 3.9375rem;
    border-bottom: 0.3125rem solid var(--border-color);
  }.a-hidden{
  display: none;
}.a-link {
  text-decoration-line: underline;
}.translation_missing {
  outline: 2px dashed hsla(162, 78%, 73%, 1);
  outline-offset: 2px;
}.l-container{
  container-type: inline-size;
}.l-container--narrow {
    --container-inline-size: 74rem;
  }.l-container__inner {
    inline-size: 100%;
    max-inline-size: calc(
      var(--container-inline-size) + 2 * var(--container-padding-inline)
    );
    margin-inline: auto;
    padding-inline: var(--container-padding-inline);
  }.l-back-container {
  display: grid;
  grid-template-columns: 1fr 0px;
}.l-back-container > *:first-child {
    /* Leave room for the back to top button at the bottom of the page */
    padding-bottom: 100px;
  }.l-max-inline-size-none {
  --max-inline-size: none;
}/* In the interest of time & reduced complexity,
use tailwind's text-[name] classes for font sizes. */:is(
    .text-h1,
    .text-h2,
    .text-h3,
    .text-h4,
    .text-h5,
    .text-h6,
    .text-label,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}.t-rte{
  max-width: 52.1875rem;
}.t-rte + .t-rte {
    margin-block-start: 1.5rem;
  }.t-rte > :where(:not(meta):not(:empty)) + * {
    margin-block-start: 1.5rem;
  }.t-rte ul,
  .t-rte ol {
    padding-inline-start: 1.25rem;
    list-style: revert;
  }.t-rte ul > li,
  .t-rte > li {
    list-style: none;
  }/* list-style-position: inside; */.t-rte ul > li::before, .t-rte > li::before {
      content: "■";
      font-size: 0.6875rem;
      line-height: 0;
      inset-block-start: -0.125rem;
      margin-inline-end: 0.3rem;
      margin-inline-start: -1.25rem;
      position: relative;
      color: hsla(162, 78%, 73%, 1);
    }.t-rte ol > li::marker {
    color: var(--color);
  }.t-rte ul > br,
  .t-rte ol > br {
    display: none;
  }.t-rte li + li {
    margin-block-start: var(--rte-li-margin-block-start, 1rem);
  }.t-rte > li {
    padding-inline-start: 1.25rem;
  }.t-rte > li::before {
      margin-inline-start: -1.25rem;
    }.t-rte a {
    text-decoration-line: underline;
    word-break: break-word;
  }.t-rte > p + br,
  .t-rte > li + br {
    display: none;
  }.t-other-text {
  --rte-li-margin-block-start: 0.5em;

  font-size: 0.875rem;
  line-height: 1.571;
}.t-other-text > :is(h3, h4, strong) {
    display: block;
    margin-block-end: 0.25em;
    font: inherit;
    font-weight: bold;
    letter-spacing: inherit;
  }/* This file is auto-generated by ./bin/rails view_component:css_manifest:update *//* Run that command whenever you add a new CSS file in ViewComponent */.back-to-top {
  --offset: 70%;

  position: sticky;
  bottom: calc(var(--comparison-bar-height, 0px) + 0px);
  place-self: end;
  margin-top: calc(100vh + var(--offset));
  inline-size: 100vw;
  pointer-events: none;
  z-index: 50;
}@media print {.back-to-top {
    display: none
}
  }.back-to-top__inner {
    display: flex;
    justify-content: flex-end;
    margin-inline: auto;
    padding: 1.5rem;
  }.back-to-top__link {
    inline-size: 100vw;
    max-inline-size: 13.625rem;
    pointer-events: all;
  }@media screen and (max-width: 48rem) {.back-to-top__link {
      gap: 0;
      padding-inline: 1rem;
      inline-size: auto
  }

      .back-to-top__link svg:last-child {
        margin-inline-end: 0;
      }.back-to-top__text{
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
  }
    }/* Add styles for this component */.comparison-bar__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(200px, 1fr));
    gap: 0.625rem;
    overflow-x: auto;
    padding-block-end: clamp(1.5rem, 1.322rem + 0.7752vw, 2rem);
  }.comparison-bar__skip {
    opacity: 0;
    /* transform: translateX(-100%); */
    transition-property: opacity;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
  }.comparison-bar__skip:not(:focus-visible){
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}.comparison-bar__skip:focus-visible {
      /* transform: translateX(0); */
      opacity: 1;
    }/* Add styles for this component */.m-comparison-bar-item {
  position: relative;
  flex: 0 0 auto;
  height: 100%;
  min-block-size: clamp(3.75rem, 3.416rem + 1.4535vw, 4.6875rem);
  padding-block: clamp(0.625rem, 0.491rem + 0.5814vw, 1rem);
  padding-inline: clamp(1rem, 0.911rem + 0.3876vw, 1.25rem);
  border-radius: 1rem;
}.m-comparison-bar-item:has(.m-comparison-bar-item__close) {
    padding-inline-end: clamp(1.875rem, 1.652rem + 0.9690vw, 2.5rem);
  }.m-comparison-bar-item:has(.m-comparison-bar-item__add-more){
  border-width: 1px;
  border-style: dashed;
  border-color: hsla(162, 78%, 73%, 1);
    display: flex;
    align-items: center;
    justify-content: center;
    padding-inline: 0.25rem;
}.m-comparison-bar-item__add-more {
    display: block;
    text-align: center;
    color: hsla(162, 78%, 73%, 1);
  }.m-comparison-bar-item__close {
    --outline-offset: 0;

    position: absolute;
    inset-block-start: 0.625rem;
    inset-inline-end: 0.4625rem;
  }/* Add styles for this component */.comparison-wrapper {
  --table-column-min: 12.5rem;
  --table-columns: calc(var(--comparison-columns) + 1);
}@media (max-width: 64rem) {.comparison-wrapper {
    --table-columns: var(--comparison-columns)
}
  }/* Always overflow x at small screens */@media (max-width: 30rem) {.comparison-wrapper {
    overflow-x: auto
}
  }/* 3 * table-column-min + gap */@media (max-width: 41rem) {.comparison-wrapper--col-3 {
      overflow-x: auto
  }
    }/* 4 * table-column-min + gap  */@media (max-width: 54rem) {.comparison-wrapper--col-4 {
      overflow-x: auto
  }
    }.comparison-header {
  position: relative;
  padding-block-start: 2rem;
}.comparison-row {
  display: grid;
  grid-template-columns: repeat(
    var(--table-columns, auto-fit),
    minmax(var(--table-column-min), 1fr)
  );
}@media print {.comparison-row {
    --table-column-min: 25%
}
  }.comparison-row > * {
    padding-inline-end: 1rem;
    padding-block: 1rem;
  }@media (max-width: 64rem) {
      .comparison-row > *:first-child {
        grid-column: 1 / -1;
      }
    }.comparison-sticky-header {
  position: sticky;
  top: -1px;
  background-color: hsla(0, 0%, 97%, 1);
  z-index: 51;
}.comparison-sticky-header--is-pinned::after {
    content: "";
    position: absolute;
    inset-block: 0;
    inset-inline: calc(var(--container-padding-inline) * -1);
    z-index: -1;
    background-color: hsla(0, 0%, 97%, 1);
  }@media (min-width: 30rem) {.comparison-sticky-header--is-pinned .comparison-sticky-header__solution {
      opacity: 1
  }
    }.comparison-sticky-header__solution {
    opacity: 0;
    padding-inline: clamp(0.875rem, 0.741rem + 0.5814vw, 1.25rem);
    padding-block: 1rem;
    height: 100%;
    border-radius: 0.75rem;
    transition-property: opacity;
    transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    transition-duration: 150ms;
  }@media (max-width: 30rem) {.comparison-sticky-header__solution {
      opacity: 1;
      margin-block-start: 2rem
  }
    }/* 3 * table-column-min + gap */@media (max-width: 41rem) {.comparison-wrapper--col-3 .comparison-sticky-header__solution {
        opacity: 1;
        margin-block-start: 2rem
    }
      }/* 4 * table-column-min + gap  */@media (max-width: 54rem) {.comparison-wrapper--col-4 .comparison-sticky-header__solution {
        opacity: 1;
        margin-block-start: 2rem
    }
      }@media (max-width: 64rem) {
    .comparison-sticky-header__heading {
      grid-row: 2;
      padding-block-start: 0;
    }

    .comparison-sticky-header div[role="columnheader"]:not(:first-child) {
      border-bottom: 0;
    }
  }.comparison-toggle {
  display: flex;
  align-items: center;
  padding-inline-end: 18px;
}.comparison-toggle::after {
    display: block;
    content: "";
    flex: 0 0 auto;
    inline-size: 1.375rem;
    block-size: 1.375rem;
    border: 0.125rem solid hsla(0, 0%, 0%, 1);
    background-color: hsla(0, 0%, 100%, 1);
  --color: hsla(0, 0%, 0%, 1);
  border-radius: 25rem;
  }.comparison-toggle[aria-pressed="true"]::after {
      background-image: radial-gradient(
        circle,
        rgba(2, 0, 36, 1) 44%,
        rgba(255, 255, 255, 1) 44%
      );
    }.expandable-text__text {
    -webkit-line-clamp: var(--truncate);
  }.expandable-text__toggle {
    margin-block-start: 0.75em;
    letter-spacing: inherit;
    font-weight: 600;
  }/* FOOTER *//* extra header classes */:root {
  --nav-height: 5.4rem;
  --nav-item-height: 2.5rem;
  --radius: 1.25rem;
  --header-link-padding: clamp(1rem, -2.718rem + 5.1064vw, 1.75rem);
}.implementation-statement + .implementation-statement {
    padding-top: 1rem;
  }.copy-button {
  /* prevents button from growing when inner text changes */
  min-inline-size: 8.6875rem;
}/* Intentionally left blank */.solution-details {
  position: relative;
  scroll-padding-top: 4.25rem;
}.solution-hero {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  column-gap: 2rem;
  row-gap: 2.6875rem;
  padding-block: 3.75rem;
}@media screen and (min-width: 64rem) {.solution-hero {
    flex-direction: row-reverse;
    justify-content: space-between
}
  }.solution-hero__text > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.25rem * var(--tw-space-y-reverse));
}@media screen and (min-width: 64rem) {.solution-hero__text {
      padding-block-start: 24px;
      flex-basis: 52.1875rem
  }
    }.solution-hero__figure {
    flex: 0 0 auto;
    inline-size: 15rem;
    max-inline-size: 100%;
    aspect-ratio: 1/1;
    padding: 1rem;
    border-radius: 1rem;
    background-color: hsla(0, 0%, 100%, 1);
    display: flex;
    align-items: center;
    justify-content: center;
  }.solution-hero__logo {
    object-fit: contain;
    max-inline-size: 100%;
    min-inline-size: 50%;
    height: auto;
    aspect-ratio: 1/1;
  }.solution-articles {
  padding-block-end: 6.25rem;
}.solution-articles > article {
    padding-block-start: clamp(3.75rem, 3.304rem + 1.9380vw, 5rem);
  }.solution-articles > article > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(2.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(2.5rem * var(--tw-space-y-reverse));
}@media (min-width: 30rem){.solution-articles > article > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(3.75rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(3.75rem * var(--tw-space-y-reverse));
  }
}/* About has a slightly smaller gap */.solution-articles > article.solution-articles__about > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse: 0;
  margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.25rem * var(--tw-space-y-reverse));
}@media (min-width: 30rem){.solution-articles > article.solution-articles__about > :not([hidden]) ~ :not([hidden]){
    --tw-space-y-reverse: 0;
    margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
  }
}.solution-articles > article > div > h3{
  font-size: clamp(1.25rem, 1.161rem + 0.3876vw, 1.5rem);
  line-height: normal;
  letter-spacing: -0.0313rem;
  font-weight: 700;
}:is(
    .text-h1,
    .text-h2,
    .text-h3,.solution-articles > article > div > h3,
    .text-h5,
    .text-h6,
    .text-label,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}.solution-articles > article > div > h3 {
    padding-block-end: var(--solution-articles-h3-padding-block-end, 1.5rem);
  }.solution-cards-wrapper:not(:has(.m-card)):not(:has(.org-structure-card)):not(:has(.multiselection-card)):not(:has(.grants-free-input)) {
    display: none;
  }.solution-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(19.6875rem, 1fr));
  gap: 1rem;
}.org-structure-card {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  border-radius: 1.25rem;
  background-color: hsla(0, 0%, 100%, 1);
  padding-block-end: 2rem;
  overflow: hidden;
}.org-structure-card > * {
    padding-inline: clamp(1.5rem, 1.322rem + 0.7752vw, 2rem);
  }.org-structure-card > h4{
  font-family: Inter, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  font-size: clamp(1rem, 0.978rem + 0.0969vw, 1.0625rem);
  line-height: 1.625rem;
  letter-spacing: -0.0156rem;
    font-weight: 600;
    background-color: hsla(162, 78%, 73%, 1);
    padding-block-start: clamp(1.25rem, 1.161rem + 0.3876vw, 1.5rem);
    padding-block-end: clamp(1rem, 0.911rem + 0.3876vw, 1.25rem);
}.grant-card {
  --card-inner-gap: 1rem;

  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.571;
}.grant-card dl {
    display: flex;
    flex-direction: column;
    gap: 0.75em;
    padding-block: 1.125rem;
    border-block: 1px solid hsla(0, 0%, 75%, 1);
  }.grant-card dt {
    display: inline;
    font-weight: 600;
  }.grant-card dd {
    display: inline;
  }.solution-filters fieldset + fieldset {
      margin-block-start: 1.5rem;
    }.solution-filters legend{
  font-size: clamp(0.9375rem, 0.915rem + 0.0969vw, 1rem);
  line-height: normal;
  letter-spacing: 0rem;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  font-weight: 600;
}.solution-filters legend + * {
      margin-block-start: 1rem;
    }.solution-filters-details {
  padding-block: 1.25rem;
  border-block-end-width: 0.0625rem;
}.solution-filters-details:first-of-type {
    border-block-start-width: 0.0625rem;
  }.solution-filters-details[open] summary::after {
    background-image: url("/assets/icons/16/Disclosure-Up-528773877752fb18f4b5e31914d13aa45f56b70b.svg");
  }.solution-filters-details summary {
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    gap: 0.875rem;
  }.solution-filters-details summary::marker {
      content: none;
    }.solution-filters-details summary::-webkit-details-marker {
      display: none;
    }.solution-filters-details summary::after {
      display: block;
      content: "";
      inline-size: 1rem;
      block-size: 1.5rem;
      background-image: url("/assets/icons/16/Disclosure-Down-3d150df2a40ce32c9183866aa8afaed956a7abc3.svg");
      background-repeat: no-repeat;
      background-position: center;
    }.solution-filters-details summary + * {
      margin-block-start: 1.1875rem;
    }.solution-filters-details h4{
  font-size: clamp(0.9375rem, 0.915rem + 0.0969vw, 1rem);
  line-height: normal;
  letter-spacing: 0rem;
  font-family: Inter, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  font-weight: 600;
    margin-block-end: -0.25rem;
    padding-block-start: 0.5rem;
}.checkbox-group {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-inline-end: calc(var(--solution-filters-padding) * -0.5);
  padding-inline-end: calc(var(--solution-filters-padding) * 0.5);
  margin-inline-start: calc(var(--outline-width) * -1);
  padding-inline-start: var(--outline-width);
  max-block-size: 16.0625rem;
  overflow-y: auto;
}.checkbox-group + * {
    margin-block-start: 1.5rem;
  }.location-select {
  padding-block: 1.25rem;
  border-block-end-width: 0.0625rem;
}.location-select select {
    inline-size: 100%;
    margin-block-start: 1rem;
  }.solution-filters {
  position: relative;
  display: grid;
  gap: 0.5rem;
}@media screen and (min-width: 64rem) and (min-height: 48rem){.solution-filters{
    display: block;
  }
}@media screen and (min-width: 23rem) {.solution-filters {
    grid-template-columns: 1fr 1fr
}
  }@media screen and (min-width: 64rem) and (min-height: 48rem) {.solution-filters{
    position: sticky;
    top: -1px;
    margin-inline-end: calc(var(--solution-filters-padding) * -0.25);
    margin-block-start: -1rem;
    padding-block: 1rem;
    padding-inline-end: calc(var(--solution-filters-padding) * 0.25);
    overflow-y: auto;
    overscroll-behavior-y: contain;
  }

    @supports (scrollbar-gutter: stable) {.solution-filters {
      scrollbar-gutter: stable;
      padding-inline-end: 0;
      margin-inline-end: 0
}
    }

    .solution-filters--is-pinned {
      max-block-size: calc(100vh - var(--comparison-bar-height, 0px));
    }
  }@starting-style {
    .solution-filters .solution_search {
      width: 100%;
    }
  }.solution-filters .solution_search {
    width: 100%;

    /* @media (prefers-reduced-motion: no-preference) { */
    transition-property: width;
    transition-duration: 150ms;
    transition-timing: cubic-bezier(0.4, 0, 0.2, 1);
  }/* } */@media screen and (min-width: 23rem) and (max-width: 30rem) {
      .solution-filters .solution_search:focus-within {
        z-index: 3;
        /* position: absolute; */
        width: calc(100vw - var(--container-padding-inline) * 2);
      }

        .solution-filters .solution_search:focus-within + .solution-mobile-filters {
          display: none;
        }
    }.solution-filters__search {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding-inline: 1.4375rem;
    block-size: clamp(3.25rem, 3.072rem + 0.7752vw, 3.75rem);
    font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    border-radius: 12.5rem;
  }.solution-filters__search:focus-within {
      --outline-offset: calc(var(--outline-width) * -1);
      outline: var(--outline-width) solid var(--outline-color);
      outline-offset: var(--outline-offset, var(--outline-width));
    }.solution-filters__search-input {
    background-color: transparent;
    block-size: 3.75rem;
    inline-size: 100%;
    padding: 0;
  }.solution-filters__search-input:focus-visible {
      outline: 0;
    }.solution-filters__filters {
    padding: var(--solution-filters-padding) var(--solution-filters-padding) calc(1.25 * var(--solution-filters-padding));
    border-radius: 1.5rem;
    margin-block-start: 1rem;
  }.solution-filters__buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    row-gap: 0.5rem;
    column-gap: 0.25rem;
  }.select-all-filters {
  display: inline-block;
  text-decoration-line: underline;
  text-transform: uppercase;
  font-size: 0.8125rem;
  letter-spacing: 0.077em;
  font-weight: 600;
}.select-all-filters:hover {
    text-decoration-color: transparent;
  }.solution-location-icon {
  block-size: 1.25rem;
}.text-xs .solution-location-icon {
    block-size: 1rem;
  }.solution-mobile-filters{
  display: block;
  min-height: clamp(3.25rem, 3.072rem + 0.7752vw, 3.75rem);
}@media screen and (min-width: 64rem) and (min-height: 48rem){.solution-mobile-filters{
    display: none;
  }
}.solution-filters-dialog-toggle {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-inline: 1.4375rem;
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}.solution-filters-dialog {
  position: fixed;
  inset: 0;
  inset-inline-start: auto;
  inline-size: 100%;
  block-size: 100%;
  max-inline-size: 30rem;
  max-block-size: none;
  margin: 0;
  transform: translateX(100%);
  overflow: auto;
  display: flex;
  flex-direction: column;

  /* Fallback open/close styles */
  opacity: 0;
  transition-property: opacity, overlay, display;
  transition-behavior: allow-discrete;
  transition-duration: 300ms;
}@media screen (prefers-reduced-motion: no-preference) {.solution-filters-dialog {
    opacity: 1;
    transition-property: transform, overlay, display;
    transition-duration: 500ms
}
  }@starting-style {
    .solution-filters-dialog[open] {
      opacity: 0;
      transform: translateX(100%);
    }

    .solution-filters-dialog::backdrop {
      background-color: rgba(0 0 0 / 0%);
    }
  }.solution-filters-dialog::backdrop {
    background-color: rgba(0 0 0 / 0%);
    transition-property: background-color, overlay, display;
    transition-duration: 500ms;
    transition-behavior: allow-discrete;
  }.solution-filters-dialog[open] {
    transform: translateX(0);
    opacity: 1;
  }.solution-filters-dialog[open]::backdrop {
      background-color: rgba(0 0 0 / 80%);
    }.solution-filters-dialog__inner {
    display: flex;
    flex-direction: column;
    margin: 0;
    padding-inline: var(--container-padding-inline);
    padding-block-start: 37px;
    padding-block-end: 3.75rem;
  }.solution-filters-dialog__header {
    display: flex;
    gap: 0.75rem;
    padding-block-end: 1.5rem;
  }.solution-filters-dialog__close {
    margin-inline-start: auto;
    margin-inline-end: -0.25rem;
    padding-block: 0;
    padding-inline: 0.25rem;
  }.solution-filters-dialog__buttons {
    display: grid;
    gap: 0.5rem;
    padding-block-end: 1.5rem;
  }@media screen and (min-width: 23rem) {.solution-filters-dialog__buttons {
      grid-template-columns: repeat(2, 1fr)
  }
    }.multiselection-card {
  --padding-inline: clamp(1.5rem, 1.322rem + 0.7752vw, 2rem);

  background-color: hsla(0, 0%, 100%, 1);

  border-radius: 1.25rem;
  overflow: hidden;
}.multiselection-card > h4 {
    padding-block-start: clamp(1.25rem, 1.161rem + 0.3876vw, 1.5rem);
    padding-block-end: clamp(1rem, 0.911rem + 0.3876vw, 1.25rem);
    padding-inline: var(--padding-inline);
    background-color: hsla(0, 0%, 92%, 1);
  }.multiselection-card__body {
    padding-inline: var(--padding-inline);
    padding-block: clamp(1.25rem, 1.161rem + 0.3876vw, 1.5rem);
  }.multiselection-card__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.625rem;
  }.multiselection {
  max-width: 52.1875rem;
}.multiselection--free-text {
    --solution-articles-h3-padding-block-end: 0.875rem;
  }.multiselection__body--columns {
      padding: 2rem 2.5rem;
      background-color: hsla(0, 0%, 100%, 1);
      border-radius: 1.25rem;
    }.multiselection__list--default {
      display: flex;
      flex-wrap: wrap;
      gap: 1rem;
    }.multiselection__list--columns-2 {
      columns: 16rem auto;
      column-gap: 1.5rem;
    }.multiselection__list--columns-3 {
      columns: 11rem auto;
      column-gap: 1.5rem;
    }.multiselection__other-label {
    font-weight: bold;
  }.solution-nav {
  --nav-bar-inline-padding: clamp(0.5rem, 0.054rem + 1.9380vw, 1.75rem);
  --nav-bar-height: clamp(3.125rem, 2.902rem + 0.9690vw, 3.75rem);

  position: sticky;
  top: -1px;
  z-index: 51;
}@media print {.solution-nav {
    position: static
}
  }/* Add styles for this component */.solutions-sort {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding-block: 0.5rem;
  padding-inline-start: clamp(1rem, 0.733rem + 1.1628vw, 1.75rem);
  border-radius: 12.5rem;
  font-size: clamp(1rem, 0.955rem + 0.1938vw, 1.125rem);
  line-height: normal;
  letter-spacing: -0.0187rem;
  font-weight: 700;
}:is(
    .text-h1,
    .text-h2,
    .text-h3,
    .text-h4,
    .text-h5,.solutions-sort,
    .text-label,
    .text-staff
  ){
  font-family: BW Gradual, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  max-inline-size: var(--max-inline-size, 52.1875rem);
}.solutions-sort{
  min-height: clamp(3.25rem, 3.072rem + 0.7752vw, 3.75rem);
}@media screen and (min-width: 23rem) {.solutions-sort{
    border-start-start-radius: 0;
    border-end-start-radius: 0;
  }
  }/* label {
    @media screen and (max-width: theme("screens.sm")) {
      @apply sr-only;
    }
  } */.solutions-sort:focus-within {
    --outline-offset: calc(var(--outline-width) * -1);

    outline: var(--outline-width) solid var(--outline-color);

    outline-offset: var(--outline-offset, var(--outline-width));
  }.solutions-sort select {
    align-self: stretch;
    padding-inline-end: clamp(2.625rem, 2.402rem + 0.9690vw, 3.25rem);
    padding-inline-start: 0.25rem;
    background-color: transparent;
    background-position: right 1.5rem center;
    font-weight: 700;
  }.solutions-sort select:focus,
    .solutions-sort select:focus-visible {
      outline: 0;
    }.structured-list {
  max-width: 52.1875rem;
}.structured-list--free-text {
    --solution-articles-h3-padding-block-end: 0.875rem;
  }.structured-list__body--boxed {
      padding: 2rem 2.5rem;
      background-color: hsla(0, 0%, 100%, 1);
      border-radius: 1.25rem;
    }.structured-list__list--columns {
      columns: 16rem auto;
      column-gap: 1.5rem;
    }.structured-list__list--columns > * {
        break-inside: avoid;
      }/* component styles */.solutions-results {
  display: grid;
  margin-block-end: 1rem;
  row-gap: 1rem;
}@media screen and (min-width: 23rem) {.solutions-results {
    grid-template-columns: 1fr auto
}
  }.solutions-results__count {
    padding-inline-start: clamp(1rem, 0.643rem + 1.5504vw, 2rem);
    padding-inline-end: 0.25rem;
    padding-block: clamp(0.625rem, 0.536rem + 0.3876vw, 0.875rem);
    border-start-start-radius: 12.5rem;
    border-end-start-radius: 12.5rem;
    border-start-end-radius: 12.5rem;
    border-end-end-radius: 12.5rem;
  }@media (min-width: 23rem){.solutions-results__count{
    border-start-end-radius: 0;
    border-end-end-radius: 0;
  }
}.solutions-results__count{
  min-height: clamp(3.25rem, 3.072rem + 0.7752vw, 3.75rem);
}.solutions-skip-link {
  position: absolute;
  display: inline-flex;
  right: 1rem;
  transform: translateX(100%);
  opacity: 0;
  z-index: 50;
  transition-property: opacity;
  transition-duration: 150ms;
  transition-timing: cubic-bezier(0.4, 0, 0.2, 1);
}@media (prefers-reduced-motion: no-preference) {.solutions-skip-link {
    transition-property: opacity, transform
}
  }.solutions-skip-link:focus-visible {
    opacity: 1;
    transform: translateX(0);
  }@media (min-width: 30rem){.sm\:mb-\[3\.75rem\]{
    margin-bottom: 3.75rem;
  }.sm\:block{
    display: block;
  }.sm\:flex{
    display: flex;
  }.sm\:hidden{
    display: none;
  }.sm\:grid-cols-solutions-list{
    grid-template-columns: repeat(auto-fit, minmax(20.375rem, 1fr));
  }.sm\:flex-row{
    flex-direction: row;
  }.sm\:px-16{
    padding-left: 4rem;
    padding-right: 4rem;
  }.sm\:pb-5{
    padding-bottom: 1.25rem;
  }.sm\:pt-5{
    padding-top: 1.25rem;
  }.sm\:pt-9{
    padding-top: 2.25rem;
  }.sm\:text-h2{
    font-size: clamp(2rem, 1.911rem + 0.3876vw, 2.25rem);
    line-height: normal;
    letter-spacing: -0.0313rem;
    font-weight: 700;
  }.sm\:text-h3{
    font-size: clamp(1.5rem, 1.455rem + 0.1938vw, 1.625rem);
    line-height: normal;
    letter-spacing: -0.0313rem;
    font-weight: 700;
  }
}@media (min-width: 48rem){.md\:text-5xl{
    font-size: 3rem;
    line-height: 1;
  }
}@media (min-width: 64rem){.lg\:px-48{
    padding-left: 12rem;
    padding-right: 12rem;
  }.lg\:py-16{
    padding-top: 4rem;
    padding-bottom: 4rem;
  }.lg\:text-6xl{
    font-size: 3.75rem;
    line-height: 1;
  }.lg\:text-xl{
    font-size: 1.375rem;
    line-height: normal;
    letter-spacing: 0rem;
    font-weight: 500;
  }.lg\:text-xs{
    font-size: clamp(0.875rem, 0.853rem + 0.0969vw, 0.9375rem);
    line-height: normal;
    letter-spacing: 0rem;
    font-weight: 500;
  }
}@media screen and (min-width: 64rem) and (min-height: 48rem){.mobile\:block{
    display: block;
  }.mobile\:grid-cols-solutions-page{
    grid-template-columns: 21.4375rem 1fr;
  }
}@media (prefers-color-scheme: dark){.dark\:bg-gray-900{
    --tw-bg-opacity: 1;
    background-color: rgb(17 24 39 / var(--tw-bg-opacity));
  }.dark\:text-gray-400{
    --tw-text-opacity: 1;
    color: rgb(156 163 175 / var(--tw-text-opacity));
  }.dark\:text-white{
    color: hsla(0, 0%, 100%, 1);
  }
}@media print{.print\:line-clamp-none{
    overflow: visible;
    display: block;
    -webkit-box-orient: horizontal;
    -webkit-line-clamp: none;
  }.print\:block{
    display: block;
  }.print\:hidden{
    display: none;
  }
}
