@charset "UTF-8";
/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-50 {
  color: #e7eaf2;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-50 {
  background-color: #e7eaf2;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-100 {
  color: #c1cae1;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-100 {
  background-color: #c1cae1;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-200 {
  color: #99a8cc;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-200 {
  background-color: #99a8cc;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-300 {
  color: #7286b7;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-300 {
  background-color: #7286b7;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-400 {
  color: #536ca9;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-400 {
  background-color: #536ca9;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-500 {
  color: #32539c;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-500 {
  background-color: #32539c;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-600 {
  color: #2c4c93;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-600 {
  background-color: #2c4c93;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-700 {
  color: #234287;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-700 {
  background-color: #234287;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-800 {
  color: #1b397b;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-800 {
  background-color: #1b397b;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-primary-900 {
  color: #0f2864;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-primary-900 {
  background-color: #0f2864;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-accent {
  color: #0ab4ff;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-accent {
  background-color: #0ab4ff;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-white {
  color: #fefefe;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-white {
  background-color: #fefefe;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-50 {
  color: rgba(0, 0, 0, 0.05);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-50 {
  background-color: rgba(0, 0, 0, 0.05);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-100 {
  color: rgba(0, 0, 0, 0.1);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-100 {
  background-color: rgba(0, 0, 0, 0.1);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-200 {
  color: rgba(0, 0, 0, 0.2);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-200 {
  background-color: rgba(0, 0, 0, 0.2);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-300 {
  color: rgba(0, 0, 0, 0.3);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-300 {
  background-color: rgba(0, 0, 0, 0.3);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-400 {
  color: rgba(0, 0, 0, 0.4);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-400 {
  background-color: rgba(0, 0, 0, 0.4);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-500 {
  color: rgba(0, 0, 0, 0.5);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-500 {
  background-color: rgba(0, 0, 0, 0.5);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-600 {
  color: rgba(0, 0, 0, 0.6);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-600 {
  background-color: rgba(0, 0, 0, 0.6);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-700 {
  color: rgba(0, 0, 0, 0.7);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-700 {
  background-color: rgba(0, 0, 0, 0.7);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-800 {
  color: rgba(0, 0, 0, 0.8);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-800 {
  background-color: rgba(0, 0, 0, 0.8);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-gray-900 {
  color: rgba(0, 0, 0, 0.9);
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-gray-900 {
  background-color: rgba(0, 0, 0, 0.9);
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-success {
  color: #059647;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-success {
  background-color: #059647;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-error {
  color: #c91d1d;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-error {
  background-color: #c91d1d;
}

/* line 41, app/assets/stylesheets/config/vars/_colors.scss */
.color-warning {
  color: #e8a530;
}

/* line 45, app/assets/stylesheets/config/vars/_colors.scss */
.bg-warning {
  background-color: #e8a530;
}

/* line 18, app/assets/stylesheets/config/vars/_font-sizes.scss */
.text-step--2 {
  font-size: clamp(0.7813rem, 0.7747rem + 0.0326vi, 0.8rem);
}

/* line 18, app/assets/stylesheets/config/vars/_font-sizes.scss */
.text-step--1 {
  font-size: clamp(0.9375rem, 0.9158rem + 0.1087vi, 1rem);
}

/* line 18, app/assets/stylesheets/config/vars/_font-sizes.scss */
.text-step-0 {
  font-size: clamp(1.125rem, 1.0815rem + 0.2174vi, 1.25rem);
}

/* line 18, app/assets/stylesheets/config/vars/_font-sizes.scss */
.text-step-1 {
  font-size: clamp(1.35rem, 1.2761rem + 0.3696vi, 1.5625rem);
}

/* line 18, app/assets/stylesheets/config/vars/_font-sizes.scss */
.text-step-2 {
  font-size: clamp(1.62rem, 1.5041rem + 0.5793vi, 1.9531rem);
}

/* line 18, app/assets/stylesheets/config/vars/_font-sizes.scss */
.text-step-3 {
  font-size: clamp(1.944rem, 1.771rem + 0.8651vi, 2.4414rem);
}

/* line 18, app/assets/stylesheets/config/vars/_font-sizes.scss */
.text-step-4 {
  font-size: clamp(2.3328rem, 2.0827rem + 1.2504vi, 3.0518rem);
}

/* line 18, app/assets/stylesheets/config/vars/_font-sizes.scss */
.text-step-5 {
  font-size: clamp(2.7994rem, 2.4462rem + 1.7658vi, 3.8147rem);
}

/* line 19, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-3xs > :not(template, [hidden="true"], [type="hidden"])
~ :not(template, [hidden="true"], [type="hidden"]) {
  margin-top: var(--space-3xs);
}

/* line 26, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-self-3xs {
  margin-top: var(--space-3xs);
}

/* line 19, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-2xs > :not(template, [hidden="true"], [type="hidden"])
~ :not(template, [hidden="true"], [type="hidden"]) {
  margin-top: var(--space-2xs);
}

/* line 26, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-self-2xs {
  margin-top: var(--space-2xs);
}

/* line 19, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-xs > :not(template, [hidden="true"], [type="hidden"])
~ :not(template, [hidden="true"], [type="hidden"]) {
  margin-top: var(--space-xs);
}

/* line 26, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-self-xs {
  margin-top: var(--space-xs);
}

/* line 19, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-sm > :not(template, [hidden="true"], [type="hidden"])
~ :not(template, [hidden="true"], [type="hidden"]) {
  margin-top: var(--space-sm);
}

/* line 26, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-self-sm {
  margin-top: var(--space-sm);
}

/* line 19, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-md > :not(template, [hidden="true"], [type="hidden"])
~ :not(template, [hidden="true"], [type="hidden"]) {
  margin-top: var(--space-md);
}

/* line 26, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-self-md {
  margin-top: var(--space-md);
}

/* line 19, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-lg > :not(template, [hidden="true"], [type="hidden"])
~ :not(template, [hidden="true"], [type="hidden"]) {
  margin-top: var(--space-lg);
}

/* line 26, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-self-lg {
  margin-top: var(--space-lg);
}

/* line 19, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-xl > :not(template, [hidden="true"], [type="hidden"])
~ :not(template, [hidden="true"], [type="hidden"]) {
  margin-top: var(--space-xl);
}

/* line 26, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-self-xl {
  margin-top: var(--space-xl);
}

/* line 19, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-2xl > :not(template, [hidden="true"], [type="hidden"])
~ :not(template, [hidden="true"], [type="hidden"]) {
  margin-top: var(--space-2xl);
}

/* line 26, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-self-2xl {
  margin-top: var(--space-2xl);
}

/* line 19, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-3xl > :not(template, [hidden="true"], [type="hidden"])
~ :not(template, [hidden="true"], [type="hidden"]) {
  margin-top: var(--space-3xl);
}

/* line 26, app/assets/stylesheets/config/vars/_spacing.scss */
.stack-self-3xl {
  margin-top: var(--space-3xl);
}

/* line 14, app/assets/stylesheets/config/vars/_shadow.scss */
.shadow-drop-inset {
  box-shadow: 0px 0px 8px 0px rgba(10, 37, 64, 0.2) inset, 0px 12px 24px rgba(50, 50, 93, 0.15);
}

/* line 13, app/assets/stylesheets/config/vars/_font-weights.scss */
.weight-regular {
  font-weight: 400;
}

/* line 13, app/assets/stylesheets/config/vars/_font-weights.scss */
.weight-medium {
  font-weight: 500;
}

/* line 13, app/assets/stylesheets/config/vars/_font-weights.scss */
.weight-bold {
  font-weight: 700;
}

/* line 16, app/assets/stylesheets/config/vars/_line-heights.scss */
.line-height-none {
  line-height: 1;
}

/* line 16, app/assets/stylesheets/config/vars/_line-heights.scss */
.line-height-tight {
  line-height: 1.1;
}

/* line 16, app/assets/stylesheets/config/vars/_line-heights.scss */
.line-height-snug {
  line-height: 1.25;
}

/* line 16, app/assets/stylesheets/config/vars/_line-heights.scss */
.line-height-normal {
  line-height: 1.5;
}

/* line 16, app/assets/stylesheets/config/vars/_line-heights.scss */
.line-height-relaxed {
  line-height: 1.625;
}

/* line 16, app/assets/stylesheets/config/vars/_line-heights.scss */
.line-height-loose {
  line-height: 2;
}

/* line 12, app/assets/stylesheets/config/vars/_vars.scss */
:root {
  --color-primary-50: #e7eaf2;
  --color-primary-100: #c1cae1;
  --color-primary-200: #99a8cc;
  --color-primary-300: #7286b7;
  --color-primary-400: #536ca9;
  --color-primary-500: #32539c;
  --color-primary-600: #2c4c93;
  --color-primary-700: #234287;
  --color-primary-800: #1b397b;
  --color-primary-900: #0f2864;
  --color-accent: #0ab4ff;
  --color-white: #fefefe;
  --color-gray-50: rgba(0, 0, 0, 0.05);
  --color-gray-100: rgba(0, 0, 0, 0.1);
  --color-gray-200: rgba(0, 0, 0, 0.2);
  --color-gray-300: rgba(0, 0, 0, 0.3);
  --color-gray-400: rgba(0, 0, 0, 0.4);
  --color-gray-500: rgba(0, 0, 0, 0.5);
  --color-gray-600: rgba(0, 0, 0, 0.6);
  --color-gray-700: rgba(0, 0, 0, 0.7);
  --color-gray-800: rgba(0, 0, 0, 0.8);
  --color-gray-900: rgba(0, 0, 0, 0.9);
  --color-success: #059647;
  --color-error: #c91d1d;
  --color-warning: #e8a530;
  --text-step--2: clamp(0.7813rem, 0.7747rem + 0.0326vi, 0.8rem);
  --text-step--1: clamp(0.9375rem, 0.9158rem + 0.1087vi, 1rem);
  --text-step-0: clamp(1.125rem, 1.0815rem + 0.2174vi, 1.25rem);
  --text-step-1: clamp(1.35rem, 1.2761rem + 0.3696vi, 1.5625rem);
  --text-step-2: clamp(1.62rem, 1.5041rem + 0.5793vi, 1.9531rem);
  --text-step-3: clamp(1.944rem, 1.771rem + 0.8651vi, 2.4414rem);
  --text-step-4: clamp(2.3328rem, 2.0827rem + 1.2504vi, 3.0518rem);
  --text-step-5: clamp(2.7994rem, 2.4462rem + 1.7658vi, 3.8147rem);
  --space-3xs: clamp(0.25rem, calc(0.23rem + 0.12vw), 0.31rem);
  --space-2xs: clamp(0.5rem, calc(0.45rem + 0.24vw), 0.63rem);
  --space-xs: clamp(0.75rem, calc(0.68rem + 0.37vw), 0.94rem);
  --space-sm: clamp(1rem, calc(0.9rem + 0.49vw), 1.25rem);
  --space-md: clamp(1.5rem, calc(1.35rem + 0.73vw), 1.88rem);
  --space-lg: clamp(2rem, calc(1.8rem + 0.98vw), 2.5rem);
  --space-xl: clamp(3rem, calc(2.71rem + 1.46vw), 3.75rem);
  --space-2xl: clamp(4rem, calc(3.61rem + 1.95vw), 5rem);
  --space-3xl: clamp(6rem, calc(5.41rem + 2.93vw), 7.5rem);
  --shadow-drop-inset: 0px 0px 8px 0px rgba(10, 37, 64, 0.2) inset,
  0px 12px 24px rgba(50, 50, 93, 0.15);
  --weight-regular: 400;
  --weight-medium: 500;
  --weight-bold: 700;
  --line-height-none: 1;
  --line-height-tight: 1.1;
  --line-height-snug: 1.25;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.625;
  --line-height-loose: 2;
  --container-narrow: 68rem;
  --container-backyard: 80rem;
  /* Easings */
  --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
  --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  --ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22);
  --ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  --ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035);
  --ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335);
  --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1);
  --ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1);
  --ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1);
  --ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1);
  --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955);
  --ease-in-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1);
  --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1);
  --ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1);
  --ease-in-out-expo: cubic-bezier(1, 0, 0, 1);
  --ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86);
  --input-font-size: clamp(1rem, calc(0.909rem + 0.45vw), 1.25rem);
}

/**
 * Minified by jsDelivr using clean-css v4.2.3.
 * Original file: /npm/modern-normalize@1.1.0/modern-normalize.css
 *
 * Do NOT use SRI with dynamically generated files! More information: https://www.jsdelivr.com/using-sri-with-dynamic-files
 */
/*! modern-normalize v1.1.0 | MIT License | https://github.com/sindresorhus/modern-normalize */
/* line 8, app/assets/stylesheets/config/_modern-normalize.scss */
*,
::after,
::before {
  box-sizing: border-box;
}

/* line 13, app/assets/stylesheets/config/_modern-normalize.scss */
html {
  -moz-tab-size: 4;
  tab-size: 4;
}

/* line 17, app/assets/stylesheets/config/_modern-normalize.scss */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

/* line 21, app/assets/stylesheets/config/_modern-normalize.scss */
body {
  margin: 0;
}

/* line 24, app/assets/stylesheets/config/_modern-normalize.scss */
body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";
}

/* line 28, app/assets/stylesheets/config/_modern-normalize.scss */
hr {
  height: 0;
  color: inherit;
}

/* line 32, app/assets/stylesheets/config/_modern-normalize.scss */
abbr[title] {
  text-decoration: underline dotted;
}

/* line 35, app/assets/stylesheets/config/_modern-normalize.scss */
b,
strong {
  font-weight: bolder;
}

/* line 39, app/assets/stylesheets/config/_modern-normalize.scss */
code,
kbd,
pre,
samp {
  font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace;
  font-size: 1em;
}

/* line 47, app/assets/stylesheets/config/_modern-normalize.scss */
small {
  font-size: 80%;
}

/* line 50, app/assets/stylesheets/config/_modern-normalize.scss */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

/* line 57, app/assets/stylesheets/config/_modern-normalize.scss */
sub {
  bottom: -0.25em;
}

/* line 60, app/assets/stylesheets/config/_modern-normalize.scss */
sup {
  top: -0.5em;
}

/* line 63, app/assets/stylesheets/config/_modern-normalize.scss */
table {
  text-indent: 0;
  border-color: inherit;
}

/* line 67, app/assets/stylesheets/config/_modern-normalize.scss */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

/* line 77, app/assets/stylesheets/config/_modern-normalize.scss */
button,
select {
  text-transform: none;
}

/* line 81, app/assets/stylesheets/config/_modern-normalize.scss */
[type="button"],
[type="reset"],
[type="submit"],
button {
  -webkit-appearance: button;
}

/* line 87, app/assets/stylesheets/config/_modern-normalize.scss */
::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/* line 91, app/assets/stylesheets/config/_modern-normalize.scss */
:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/* line 94, app/assets/stylesheets/config/_modern-normalize.scss */
:-moz-ui-invalid {
  box-shadow: none;
}

/* line 97, app/assets/stylesheets/config/_modern-normalize.scss */
legend {
  padding: 0;
}

/* line 100, app/assets/stylesheets/config/_modern-normalize.scss */
progress {
  vertical-align: baseline;
}

/* line 103, app/assets/stylesheets/config/_modern-normalize.scss */
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/* line 107, app/assets/stylesheets/config/_modern-normalize.scss */
[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

/* line 111, app/assets/stylesheets/config/_modern-normalize.scss */
::-webkit-search-decoration {
  -webkit-appearance: none;
}

/* line 114, app/assets/stylesheets/config/_modern-normalize.scss */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

/* line 118, app/assets/stylesheets/config/_modern-normalize.scss */
summary {
  display: list-item;
}

/* line 1, app/assets/stylesheets/config/_globals.scss */
* {
  padding: 0;
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-tap-highlight-color: transparent;
  outline-offset: 3px;
}

/* line 13, app/assets/stylesheets/config/_globals.scss */
html,
body {
  min-block-size: 100%;
}

/* line 18, app/assets/stylesheets/config/_globals.scss */
body {
  display: flex;
  flex-direction: column;
  font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
  min-block-size: 100vh;
  min-block-size: 100dvh;
  color: var(--color-gray-800);
}

/* line 29, app/assets/stylesheets/config/_globals.scss */
:where(p) {
  max-inline-size: 60ch;
  text-wrap: pretty;
}

/* line 34, app/assets/stylesheets/config/_globals.scss */
main {
  padding-block: var(--space-xl);
}

/* line 38, app/assets/stylesheets/config/_globals.scss */
img,
svg,
video,
canvas,
iframe {
  display: block;
  block-size: auto;
  max-inline-size: 100%;
}

/* line 48, app/assets/stylesheets/config/_globals.scss */
svg {
  flex-shrink: 0;
}

/* line 52, app/assets/stylesheets/config/_globals.scss */
:where(button, input[type="submit"]) {
  background: transparent;
  border: none;
  color: inherit;
}

/* line 58, app/assets/stylesheets/config/_globals.scss */
button,
summary,
:where(input[type="submit"]) {
  cursor: pointer;
}

/* line 64, app/assets/stylesheets/config/_globals.scss */
summary {
  user-select: none;
}

/* line 68, app/assets/stylesheets/config/_globals.scss */
a {
  color: inherit;
  text-decoration: underline;
}

/* line 73, app/assets/stylesheets/config/_globals.scss */
:is(ul, ol):where([role="list"]) {
  padding: 0;
  list-style-type: none;
}

/* line 78, app/assets/stylesheets/config/_globals.scss */
.sr-only {
  position: absolute;
  overflow: hidden;
  padding: 0;
  border-width: 0;
  margin: -1px;
  block-size: 1px;
  clip: rect(0, 0, 0, 0);
  inline-size: 1px;
  white-space: nowrap;
}

@media (prefers-reduced-motion: reduce) {
  /* line 91, app/assets/stylesheets/config/_globals.scss */
  *,
*::before,
*::after {
    animation-duration: 0.01s !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01s !important;
  }
}

/* line 101, app/assets/stylesheets/config/_globals.scss */
.turbo-progress-bar {
  background: #000;
}

/* line 105, app/assets/stylesheets/config/_globals.scss */
[hidden] {
  display: none !important;
}

/* line 109, app/assets/stylesheets/config/_globals.scss */
.main-headline {
  letter-spacing: -0.025em;
  font-size: var(--text-step-5);
  line-height: var(--line-height-none);
  font-weight: var(--weight-bold);
  color: var(--color-primary-700);
}

@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Poppins";
  font-style: normal;
  font-weight: 400;
  src: url(/fonts/poppins-v20-latin-regular.woff2) format("woff2");
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* poppins-italic - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Poppins";
  font-style: italic;
  font-weight: 400;
  src: url(/fonts/poppins-v20-latin-italic.woff2) format("woff2");
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* poppins-500 - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Poppins";
  font-style: normal;
  font-weight: 500;
  src: url(/fonts/poppins-v20-latin-500.woff2) format("woff2");
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* poppins-500italic - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Poppins";
  font-style: italic;
  font-weight: 500;
  src: url(/fonts/poppins-v20-latin-500italic.woff2) format("woff2");
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* poppins-700 - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Poppins";
  font-style: normal;
  font-weight: 700;
  src: url(/fonts/poppins-v20-latin-700.woff2) format("woff2");
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* poppins-700italic - latin */
@font-face {
  font-display: swap;
  /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Poppins";
  font-style: italic;
  font-weight: 700;
  src: url(/fonts/poppins-v20-latin-700italic.woff2) format("woff2");
  /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}

/* line 1, app/assets/stylesheets/utils/_container.scss */
.container {
  width: min(100% - var(--container-padding, var(--space-sm)) * 2, var(--container-max, 60rem));
  margin-inline: auto;
}

/* line 1, app/assets/stylesheets/utils/_cluster.scss */
.cluster {
  display: flex;
  flex-wrap: wrap;
  justify-content: var(--cluster-justification, flex-start);
  align-items: var(--cluster-alignment, flex-start);
  gap: var(--cluster-gap-vertical, var(--cluster-gap, var(--space-xs))) var(--cluster-gap, var(--space-xs));
}

/* line 1, app/assets/stylesheets/atoms/_button.scss */
.button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding-inline: 1.5em;
  height: 3rem;
  gap: 1ch;
  border-radius: 999px;
  background-color: var(--color-primary-900);
  line-height: 1;
  color: var(--color-white);
  font-weight: var(--weight-medium);
  transition: background-color 0.3s;
  font-size: var(--text-step--1);
  text-decoration: none;
}

/* line 17, app/assets/stylesheets/atoms/_button.scss */
.button:is(:hover, :focus-visible) {
  background-color: var(--color-primary-600);
}

/* line 21, app/assets/stylesheets/atoms/_button.scss */
.button svg {
  --size: 1.5rem;
  width: var(--size);
  height: var(--size);
  margin-inline: -0.25em;
}

/* line 30, app/assets/stylesheets/atoms/_button.scss */
.button--secondary {
  background-color: var(--color-primary-100);
  color: var(--color-primary-900);
  font-size: 0.9375rem;
  font-weight: bold;
}

/* line 36, app/assets/stylesheets/atoms/_button.scss */
.button--secondary:is(:hover, :focus-visible) {
  background-color: var(--color-primary-200);
}

/* line 41, app/assets/stylesheets/atoms/_button.scss */
.button--small {
  height: 2.25rem;
  padding-inline: 1rem;
  font-size: 0.875rem;
  font-weight: bold;
}

/* line 47, app/assets/stylesheets/atoms/_button.scss */
.button--small svg {
  --size: 1.25rem;
}

/* line 52, app/assets/stylesheets/atoms/_button.scss */
.button--text {
  background-color: transparent;
  color: var(--color-primary-900);
  text-decoration: none;
  padding-inline: 0.5em;
}

/* line 58, app/assets/stylesheets/atoms/_button.scss */
.button--text:is(:hover, :focus-visible) {
  background-color: var(--color-primary-50);
}

/* line 63, app/assets/stylesheets/atoms/_button.scss */
.button--icon {
  padding: 0;
  aspect-ratio: 1;
}

/* line 1, app/assets/stylesheets/atoms/_input.scss */
.form {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  max-width: 30rem;
}

/* line 8, app/assets/stylesheets/atoms/_input.scss */
.form__actions {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap-reverse;
  gap: var(--space-xs);
  margin-left: auto;
}

/* line 16, app/assets/stylesheets/atoms/_input.scss */
.input-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--space-3xs);
}

/* line 21, app/assets/stylesheets/atoms/_input.scss */
.input-wrapper > label {
  font-size: var(--text-step--1);
  font-weight: 500;
  padding-inline-start: 0.25em;
  color: var(--color-gray-700);
}

/* line 27, app/assets/stylesheets/atoms/_input.scss */
.input-wrapper > label + span {
  padding-inline-start: 0.25em;
  font-size: var(--text-step--2);
  color: var(--color-gray-600);
  font-weight: 500;
}

/* line 35, app/assets/stylesheets/atoms/_input.scss */
.input-wrapper:has(> input[type="checkbox"]) {
  flex-direction: row;
  align-items: flex-start;
  gap: 0.75rem;
  padding-inline: 0.25rem;
}

/* line 41, app/assets/stylesheets/atoms/_input.scss */
.input-wrapper:has(> input[type="checkbox"]) input[type="checkbox"] {
  accent-color: var(--color-primary-900);
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
}

/* line 48, app/assets/stylesheets/atoms/_input.scss */
.input-wrapper:has(> input[type="checkbox"]) label {
  user-select: none;
  padding-inline-start: 0;
  cursor: pointer;
}

/* line 56, app/assets/stylesheets/atoms/_input.scss */
.input {
  border-radius: 0.5rem;
  border: 2px solid var(--color-gray-300);
  height: 3rem;
  padding-inline: 1rem;
  transition: 0.2s;
  transition-property: border-color, box-shadow;
}

/* line 64, app/assets/stylesheets/atoms/_input.scss */
.input:is(textarea) {
  resize: vertical;
  min-height: 3rem;
  height: auto;
  padding-block: 0.75rem;
}

/* line 71, app/assets/stylesheets/atoms/_input.scss */
.input:is(select) {
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg aria-hidden='true' xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 10 6'%3E%3Cpath stroke='%23888' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m1 1 4 4 4-4'/%3E%3C/svg%3E");
  background-position: right 0.75rem center;
  background-repeat: no-repeat;
  background-size: 0.75em 0.75em;
}

/* line 81, app/assets/stylesheets/atoms/_input.scss */
.field_with_errors .input {
  width: 100%;
}

/* line 85, app/assets/stylesheets/atoms/_input.scss */
.input::placeholder {
  color: var(--color-gray-500);
}

/* line 89, app/assets/stylesheets/atoms/_input.scss */
.input:focus-visible {
  border-color: var(--color-primary-900);
  box-shadow: 0 0 0 2px var(--color-primary-300);
  outline: none;
}

/* line 1, app/assets/stylesheets/pages/_landingpage.scss */
.landingpage__form {
  max-width: 35rem;
}

/* line 4, app/assets/stylesheets/pages/_landingpage.scss */
.landingpage__form > input {
  flex: 1;
}

/* line 8, app/assets/stylesheets/pages/_landingpage.scss */
.landingpage__form > .button {
  margin-left: auto;
}

/* line 1, app/assets/stylesheets/components/_chat.scss */
.chat-wrapper {
  flex: 1;
  padding-block: 0;
  display: flex;
  flex-direction: column;
  position: relative;
  --container-padding: 0.75rem;
}

/* line 10, app/assets/stylesheets/components/_chat.scss */
.chat-view {
  inset: 0;
  position: absolute;
  display: grid;
  grid-template-rows: 1fr auto;
  height: 100%;
}

/* line 18, app/assets/stylesheets/components/_chat.scss */
.chat {
  flex: 1;
  margin-block: 0.5rem;
  border-radius: 0.75rem;
  background: var(--color-gray-50);
  overflow: hidden;
  scrollbar-color: var(--color-primary-300) var(--color-primary-50);
}

/* line 27, app/assets/stylesheets/components/_chat.scss */
.chat__list {
  gap: 1rem;
  scrollbar-width: thin;
  overscroll-behavior: contain;
  display: flex;
  flex-direction: column-reverse;
  padding: 0.75rem;
  block-size: 100%;
  overflow-y: auto;
}

/* line 38, app/assets/stylesheets/components/_chat.scss */
.chat__message {
  display: inline-flex;
  gap: 0.25rem;
  width: clamp(90%, 40rem);
}

/* line 44, app/assets/stylesheets/components/_chat.scss */
.chat__message--system {
  align-self: flex-start;
}

/* line 48, app/assets/stylesheets/components/_chat.scss */
.chat__message--user {
  align-self: flex-end;
  flex-direction: row-reverse;
}

/* line 53, app/assets/stylesheets/components/_chat.scss */
.chat__message-icon {
  flex-shrink: 0;
  --size: 1.75rem;
  padding: 0.25rem;
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}

/* line 65, app/assets/stylesheets/components/_chat.scss */
.chat__message--system .chat__message-icon {
  background-color: var(--color-gray-100);
  color: var(--color-primary-900);
}

/* line 70, app/assets/stylesheets/components/_chat.scss */
.chat__message--user .chat__message-icon {
  background-color: var(--color-primary-100);
  color: var(--color-primary-900);
}

/* line 76, app/assets/stylesheets/components/_chat.scss */
.chat__message-content {
  padding: 0.5rem 0.75rem;
  border-radius: 0.75rem;
  font-size: 0.9375rem;
  line-height: 1.5;
}

/* line 83, app/assets/stylesheets/components/_chat.scss */
.chat__message-content:empty::after {
  content: "…";
}

/* line 88, app/assets/stylesheets/components/_chat.scss */
.chat__message--user .chat__message-content {
  background-color: var(--color-primary-800);
  color: var(--color-white);
}

/* line 93, app/assets/stylesheets/components/_chat.scss */
.chat__message--system .chat__message-content {
  background-color: var(--color-gray-100);
}

/* line 98, app/assets/stylesheets/components/_chat.scss */
.chat__message-content,
.markdown {
  line-height: 1.5;
}

/* line 102, app/assets/stylesheets/components/_chat.scss */
.chat__message-content > * + *,
.markdown > * + * {
  margin-block-start: 0.75rem;
}

/* line 106, app/assets/stylesheets/components/_chat.scss */
.chat__message-content > :is(ul, ol),
.markdown > :is(ul, ol) {
  padding-inline-start: 1.5rem;
}

/* line 109, app/assets/stylesheets/components/_chat.scss */
.chat__message-content > :is(ul, ol) li + li,
.markdown > :is(ul, ol) li + li {
  margin-block-start: 0.5rem;
}

/* line 115, app/assets/stylesheets/components/_chat.scss */
.chat-form {
  height: var(--chat-form-height);
  display: flex;
  gap: 0.5rem;
  align-items: flex-end;
  padding-block: 0.5rem;
}

/* line 122, app/assets/stylesheets/components/_chat.scss */
.chat-form .input {
  resize: none;
}

/* line 127, app/assets/stylesheets/components/_chat.scss */
.chat-form__autogrow-wrap {
  width: 100%;
  /* easy way to plop the elements on top of each other and have them both sized based on the tallest one's height */
  display: grid;
}

/* line 132, app/assets/stylesheets/components/_chat.scss */
.chat-form__autogrow-wrap::after {
  /* Note the weird space! Needed to preventy jumpy behavior */
  content: attr(data-replicated-value) " ";
  /* This is how textarea text behaves */
  white-space: pre-wrap;
  /* Hidden from view, clicks, and screen readers */
  visibility: hidden;
}

/* line 142, app/assets/stylesheets/components/_chat.scss */
.chat-form__autogrow-wrap > textarea {
  /* You could leave this, but after a user resizes, then it ruins the auto sizing */
  resize: none;
  /* Firefox shows scrollbar on growth, you can hide like this. */
  overflow: hidden;
}

/* line 150, app/assets/stylesheets/components/_chat.scss */
.chat-form__autogrow-wrap > textarea, .chat-form__autogrow-wrap::after {
  /* Identical styling required!! */
  padding: 0.75rem;
  line-height: 1.4;
  /* Place on top of each other */
  grid-area: 1 / 1 / 2 / 2;
}

/* line 162, app/assets/stylesheets/components/_chat.scss */
.chat__empty-placeholder {
  padding-block: var(--space-md);
  text-align: center;
}

/* line 2, app/assets/stylesheets/components/_navigation.scss */
.header__home-link > svg {
  height: var(--space-lg);
}

/* line 7, app/assets/stylesheets/components/_navigation.scss */
.nav-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 0;
}

/* line 13, app/assets/stylesheets/components/_navigation.scss */
.nav-wrapper a {
  text-underline-offset: 0.1em;
}

/* line 18, app/assets/stylesheets/components/_navigation.scss */
.nav__link {
  display: inline-flex;
  align-items: center;
  height: 2.5rem;
  padding-inline: 0.5rem;
}

/* line 1, app/assets/stylesheets/components/_footer.scss */
.footer {
  margin-top: auto;
  padding-block: 0.5rem;
  font-weight: 500;
  color: var(--color-gray-700);
  font-size: 0.875rem;
}

/* line 8, app/assets/stylesheets/components/_footer.scss */
.footer ul {
  --cluster-justification: flex-end;
}

/* line 13, app/assets/stylesheets/components/_footer.scss */
.footer__content {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-sm);
  align-items: center;
}

/* line 1, app/assets/stylesheets/components/_flash-message.scss */
.flash-messages {
  position: sticky;
  top: 0;
  z-index: 1000;
}

/* line 7, app/assets/stylesheets/components/_flash-message.scss */
.flash-message {
  background: var(--color-error);
  color: var(--color-white);
  padding-block: 0.5rem;
}

/* line 13, app/assets/stylesheets/components/_flash-message.scss */
.flash-message.notice {
  background: var(--color-warning);
  color: black;
}

/* line 18, app/assets/stylesheets/components/_flash-message.scss */
.flash-message.success {
  background: var(--color-success);
}

/* line 22, app/assets/stylesheets/components/_flash-message.scss */
.flash-message .container {
  display: flex;
  justify-content: space-between;
  gap: var(--space-sm);
  align-items: center;
  font-weight: 500;
}

/* line 31, app/assets/stylesheets/components/_flash-message.scss */
.flash-message__close {
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* line 38, app/assets/stylesheets/components/_flash-message.scss */
.flash-message__close svg {
  width: 1.5rem;
  height: 1.5rem;
}
