:root {
  --vs-portal-font: "Inter";
  /* color palettes */
  --red-50: #fff3f5;
  --red-100: #ffd9df;
  --red-200: #ffbec9;
  --red-300: #ed8092;
  --red-400: #e7556e;
  --red-500: #db0025;
  --red-600: #bd0020;
  --red-700: #a5001c;
  --red-800: #6e0013;
  --red-900: #41000b;
  --blue-50: #f6f9ff;
  --blue-100: #e5ecff;
  --blue-200: #bccefe;
  --blue-300: #86a1f4;
  --blue-400: #5d80ed;
  --blue-500: #4c71d2;
  --blue-600: #3c5aaa;
  --blue-700: #41538a;
  --blue-800: #2f3e6d;
  --blue-900: #1f2e5c;
  --teal-50: #f6ffeb;
  --teal-100: #e7f7d0;
  --teal-200: #d9f2b6;
  --teal-300: #cbeba0;
  --teal-400: #b1e26e;
  --teal-500: #81b23d;
  --teal-600: #638c2a;
  --teal-700: #48720f;
  --teal-800: #3d5c12;
  --teal-900: #2a4208;
  --yellow-50: #fffaec;
  --yellow-100: #fde9b4;
  --yellow-200: #fedc85;
  --yellow-300: #fec841;
  --yellow-400: #ffb800;
  --yellow-500: #fc9700;
  --yellow-600: #f67f00;
  --yellow-700: #ec6200;
  --yellow-800: #e34521;
  --yellow-900: #c52703;
  --neut-0: #ffffff;
  --neut-100: #fafafa;
  --neut-200: #f2f2f2;
  --neut-300: #dedede;
  --neut-400: #b2b2b2;
  --neut-500: #767676;
  --neut-600: #666666;
  --neut-700: #404041;
  --neut-800: #333333;
  --neut-900: #2a2a2a;
  --neut-1000: #000000;
  /* light theme */
  --primary: var(--red-500);
  --primary-focus: var(--red-600);
  --primary-content: var(--neut-0);
  --secondary: var(--blue-500);
  --secondary-focus: var(--blue-600);
  --secondary-content: var(--neut-0);
  --accent: var(--teal-700);
  --accent-focus: var(--teal-800);
  --accent-content: var(--neut-0);
  --neutral: var(--neut-900);
  --neutral-focus: var(--neut-1000);
  --neutral-content: var(--neut-0);
  --base-100: var(--neut-0);
  --base-200: var(--neut-100);
  --base-300: var(--neut-200);
  --base-content: var(--neut-900);
  --base-content-variant: var(--neut-600);
  /* semantic */
  --info: var(--blue-50);
  --info-focus: var(--blue-500);
  --info-content: var(--blue-900);
  --success: var(--teal-50);
  --success-focus: var(--teal-600);
  --success-content: var(--teal-900);
  --warning: var(--yellow-50);
  --warning-focus: var(--yellow-600);
  --warning-content: var(--neut-900);
  --error: var(--red-50);
  --error-focus: var(--red-600);
  --error-content: var(--red-900);
  --disabled: var(--neut-200);
  --disabled-focus: var(--neut-300);
  --disabled-content: var(--neut-400);
}

h1 {
  margin: 0;
}

.shadow {
  box-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
}
.shadow-md {
  box-shadow: 0 4px 12px -1px rgb(0 0 0 / 0.08),
    0 2px 6px -2px rgb(0 0 0 / 0.08);
}
.shadow-lg {
  box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
}
.shadow-xl {
  box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1),
    0 8px 10px -6px rgb(0 0 0 / 0.1);
}

.vs-display-lg-bold {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-size: 3rem;
  font-weight: 700;
}
.vs-display-md-bold {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 2rem;
}
.vs-display-sm-bold {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 1.5rem;
}
.vs-heading-xl-bold {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 2.5rem;
}
.vs-heading-lg-bold {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 1.75rem;
}
.vs-heading-md-bold {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 1.5rem;
}
.vs-heading-sm-bold {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 1.25rem;
}
.vs-heading-xs-bold {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 1.125rem;
}
.vs-heading-xs-medium {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 500;
  font-size: 1.125rem;
}
.vs-label-lg-medium {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0em;
  font-weight: 500;
  font-size: 1.125rem;
}
.vs-label-md-medium {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0em;
  font-weight: 500;
  font-size: 1rem;
}
.vs-label-sm-medium {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0.02em;
  font-weight: 500;
  font-size: 0.875rem;
}
.vs-label-xs-medium {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0.02em;
  font-weight: 500;
  font-size: 0.75rem;
}
.vs-label-xs-regular {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0.02em;
  font-weight: 400;
  font-size: 0.75rem;
}
.vs-body-lg-regular {
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 1.125rem;
}
.vs-body-md-regular {
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 1rem;
}
.vs-body-md-medium {
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 500;
  font-size: 1rem;
}
.vs-body-md-bold {
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 700;
  font-size: 1rem;
}
.vs-body-sm-regular {
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 0.875rem;
}
.vs-body-sm-medium {
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 500;
  font-size: 0.875rem;
}
.vs-body-xs-regular {
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 0.75rem;
}

.mt-4 {
  margin-top: 16px;
}

.mt-16 {
  margin-top: 64px;
}

.spinner1 {
  animation: anim_spin 1.05s infinite;
}
.spinner2 {
  animation-delay: 0.1s;
}
.spinner3 {
  animation-delay: 0.2s;
}
@keyframes anim_spin {
  0%,
  57.14% {
    animation-timing-function: cubic-bezier(0.33, 0.66, 0.66, 1);
    transform: translate(0);
  }
  28.57% {
    animation-timing-function: cubic-bezier(0.33, 0, 0.66, 0.33);
    transform: translateY(-6px);
  }
  100% {
    transform: translate(0);
  }
}

.link-skip-to-main {
  position: fixed;
  z-index: 100;
  left: 26px;
  top: 64px;
  text-decoration: none;
}
.link-skip-to-main > button {
  padding: 12px 24px;
  border-radius: 4px;
  justify-content: center;
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0.02em;
  font-weight: 500;
  font-size: 0.875rem;
}

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

.tooltip-wrapper {
  position: relative;
}
.tooltip-wrapper .tooltip {
  background-color: #333;
  color: #fff;
  border-radius: 4px;
  padding: 4px 8px;
  display: none;
  position: absolute;
  text-align: center;
  z-index: 999;
}
.tooltip-wrapper::before {
  background-color: #333;
  content: " ";
  display: none;
  position: absolute;
  width: 4px;
  height: 4px;
  z-index: 999;
}
.tooltip-wrapper:hover .tooltip {
  display: block;
}
.tooltip-wrapper:hover::before {
  display: block;
}
.tooltip-wrapper.hide:hover .tooltip {
  display: none;
}
.tooltip-wrapper.hide:hover::before {
  display: none;
}
.tooltip-wrapper.bottom .tooltip {
  content: "bottom";
  bottom: 0;
  left: 50%;
  transform: translate(-50%, calc(100% + 3px));
  white-space: nowrap;
  font-family: var(--vs-portal-font);
}
.tooltip-wrapper.bottom::before {
  bottom: 0;
  left: 50%;
  transform: translate(-50%, calc(100% + 1px)) rotate(45deg);
}

.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;
}

.btn {
  transition: all 150ms linear;
  cursor: pointer;
  border: none;
  background-color: transparent;
  display: flex;
  justify-content: center;
  align-items: center;
}

.btn:focus {
  outline: solid;
  outline-offset: 4px;
  outline-color: var(--secondary);
  outline-width: 2px;
}

.btn-default {
  background-color: var(--neut-100);
  color: var(--base-content);
  border: 1px solid var(--neut-100);
}
.btn-default:hover {
  background-color: var(--neut-200);
  border-color: var(--neut-200);
}
.btn-default:active {
  background-color: var(--neut-300);
  border-color: var(--neut-300);
}

.btn-default-outlined {
  background-color: transparent;
  color: var(--base-content);
  border: 1px solid var(--neut-400);
}
.btn-default-outlined:hover {
  background-color: var(--neut-200);
  border-color: var(--neut-200);
}
.btn-default-outlined:active {
  background-color: var(--neut-300);
  border-color: var(--neut-400);
}

.btn-neutral-outlined {
  background-color: transparent;
  color: var(--base-content);
  border: 1px solid var(--neutral);
}
.btn-neutral-outlined:hover,
.btn-neutral-outlined:active {
  background-color: var(--neutral-focus);
  border-color: var(--neutral-focus);
  color: var(--neutral-content);
}

.btn-primary {
  background-color: var(--primary);
  color: var(--primary-content);
  border: 1px solid var(--primary);
}
.btn-primary:hover,
.btn-primary:active {
  background-color: var(--primary-focus);
  border-color: var(--primary-focus);
}
.btn-secondary {
  background-color: var(--secondary);
  color: var(--secondary-content);
  border: 1px solid var(--secondary);
}
.btn-secondary:hover,
.btn-secondary:active {
  background-color: var(--secondary-focus);
  border-color: var(--secondary-focus);
}
.btn-ghost {
  background-color: transparent;
  color: var(--base-content);
  border: 1px solid transparent;
}
.btn-ghost:hover {
  background-color: var(--neut-200);
  border-color: var(--neut-200);
}
.btn-ghost:active {
  background-color: var(--neut-300);
  border-color: var(--neut-300);
}
.btn.btn-disabled {
  background-color: var(--disabled);
  color: var(--disabled-content);
  border-color: var(--disabled);
  cursor: not-allowed;
}
.btn.btn-disabled:hover,
.btn.btn-disabled:active {
  pointer-events: none;
  background-color: var(--disabled);
  border-color: var(--disabled);
}

.btn-secondary-page {
  padding: 12px 24px;
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0.02em;
  font-weight: 500;
  font-size: 0.875rem;
  border-radius: 8px;
}

.alert-box {
  padding: 8px 16px;
  border-radius: 8px;
  border: 1px solid currentColor;
  display: flex;
  align-items: center;
}
.alert-box > img {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin-inline-end: 8px;
}
.alert-box > :not(img) {
  flex: 1 1 auto;
  color: var(--base-content);
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 500;
  font-size: 0.875rem;
}

.alert-warning {
  border-color: var(--warning-focus);
  background-color: var(--warning);
}
.alert-error {
  border-color: var(--error-focus);
  background-color: var(--error);
}
.alert-success {
  border-color: var(--success-focus);
  background-color: var(--success);
}

* {
  box-sizing: border-box;
}

html {
  background-color: var(--neut-200);
}

button,
a {
  cursor: pointer;
}

input::-ms-clear,
input::-ms-reveal {
  display: none;
}

.s2 {
  display: none;
}

.header {
  height: 56px;
  padding: 8px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: var(--neut-200);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  transition: all 150ms linear;
  z-index: 10;
}
.header > img {
  height: 20px;
  width: auto;
  cursor: pointer;
}

.footer {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  padding: 16px 0;
  width: 100%;
  margin-top: 32px;
}
.footer > * {
  color: var(--base-content);
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0.02em;
  font-weight: 400;
  font-size: 0.75rem;
}
.footer > a {
  margin-bottom: 4px;
}
.footer > a:first-child {
  margin-inline-end: 12px;
}
.footer > a:last-child {
  margin-inline-start: 12px;
}

.btn-sign-in-up {
  color: var(--base-content);
  border-radius: 4px;
  padding: 8px 16px;
}

.page-container {
  min-height: calc(100vh - 56px);
  height: 1px;
  margin-top: 56px;
  padding-top: 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.page-error {
  background-image: url("/auth/assets/images/pattern-top-page.png"),
    url("/auth/assets/images/pattern-left-page.png"),
    url("/auth/assets/images/pattern-right-page.png");
  background-position: right top, left bottom, right bottom;
  background-repeat: no-repeat;
  background-size: 50% 25%, 41% 20%, 80% 68%;
}
.page-error .header,
.page-error .footer {
  background-color: transparent;
}

.content-container {
  width: 100%;
  padding-left: 24px;
  padding-right: 24px;
  flex: 1 1 auto;
}
.content-box {
  padding: 24px;
  border-radius: 8px;
  background-color: var(--base-100);
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.content-container-error {
  width: 100%;
  padding-left: 24px;
  padding-right: 24px;
  flex: 1 1 auto;
  display: flex;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.content-container-error > h1 {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 2rem;
  margin-bottom: 16px;
  color: var(--base-content);
}
.content-container-error > h5 {
  padding-top: 8px;
  color: var(--base-content-variant);
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 0.875rem;
}

.content-container-msg {
  width: 100%;
  padding-top: 32px;
  padding-left: 24px;
  padding-right: 24px;
  flex: 1 1 auto;
}
.content-box-msg {
  flex: 1 1 auto;
  border-radius: 16px;
  background-color: var(--base-100);
  min-height: 400px;
  padding-top: 65px;
  padding-bottom: 65px;
  padding-left: 40px;
  padding-right: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.content-box-msg > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 4;
}
.content-box-msg > div > * {
  text-align: center;
}
.content-box-msg > div > h1 {
  color: var(--base-content);
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 1.5rem;
}
.content-box-msg > div > h2 {
  padding-top: 8px;
  color: var(--base-content-variant);
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 0.875rem;
}
.content-box-msg > div > button {
  padding: 12px 24px;
  border-radius: 8px;
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0.02em;
  font-weight: 500;
  font-size: 0.875rem;
  margin-top: 24px;
}
.content-box-msg > span:first-of-type {
  z-index: 3;
  height: 48px;
  width: 76%;
  position: absolute;
  right: 0;
  top: 0;
  overflow: hidden;
}
.content-box-msg > span:last-of-type {
  overflow: hidden;
  z-index: 2;
  width: 58%;
  height: 160px;
  position: absolute;
  right: 0;
  bottom: 0;
}
.content-box-msg > span {
  display: flex;
  justify-content: flex-end;
}
.content-box-msg > span > img {
  object-fit: contain;
}

.content-box-msg-bg {
  background-image: url("/auth/assets/images/pattern-top-box.png"),
    url("/auth/assets/images/pattern-bottom-box.png");
  background-position: top 0px right 0px, bottom 0px right 0px;
  background-repeat: no-repeat;
  background-size: auto 12%, auto 40%;
  /* background-size: auto 22%, auto 73%; */
  background-origin: border-box;
}

.content-footer {
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.content-footer-signup {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  color: var(--base-content);
}
.content-footer-signup > a {
  margin-inline-start: 8px;
}
.content-footer-lang {
  display: flex;
  align-items: center;
}
.content-footer-lang:focus-within {
  outline: solid;
  outline-offset: 4px;
  outline-color: var(--secondary);
  outline-width: 2px;
  border-radius: 4px;
}
.content-footer-lang > img {
  width: 18px;
  height: 18px;
}
.content-footer-lang > select {
  border: none;
  background-color: transparent;
  padding: 8px 12px;
}

.f-rs {
  cursor: pointer;
}

.page-title-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 24px;
  text-align: center;
}
.page-title-box > h1 {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--base-content);
  display: flex;
  align-items: center;
  white-space: pre-wrap;
}
.page-title-box > h1 > img {
  width: 32px;
  height: 24px;
  margin-inline-end: 8px;
}
.page-title-box > h2 {
  margin-top: 4px;
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 0.75rem;
  color: var(--base-content-variant);
  display: flex;
  align-items: center;
}

.page-title-box > h2 > img:last-of-type {
  width: 20px;
  height: 20px;
  margin-inline-start: 4px;
  cursor: pointer;
}

.qrcode-login-title-box {
  margin-bottom: 0px;
  margin-top: 24px;
}

.sso-btns {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 8px;
  flex: 0;
}
.sso-btns button {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 12px;
  border-radius: 50%;
}
.sso-btns button > img {
  width: 24px;
  height: 24px;
}

.sso-more-option {
  position: relative;
  display: inline-block;
  cursor: pointer;
}
.sso-more-option-dropdown {
  display: none;
  position: absolute;
  max-width: 240px;
  min-width: 160px;
  box-shadow: 0px 4px 12px -1px rgba(0, 0, 0, 0.08),
    0px 2px 6px -2px rgba(0, 0, 0, 0.08);
  z-index: 1;
  left: auto;
  right: 0;
  padding: 1rem;
  background-color: white;
  border-radius: 8px;
}
.show-sso-more {
  display: block;
}
.sso-more-option-dropdown > form {
  margin-bottom: 0;
}
.sso-more-option-dropdown .sso-more-option-item {
  display: flex;
  align-items: center;
  justify-content: start;
  padding: 8px 12px;
  border-radius: 8px;
  border: none;
  background-color: transparent;
  width: 100%;
}
.sso-more-option-dropdown .sso-more-option-item:hover {
  background-color: #f2f2f2;
}
.sso-more-option-dropdown .sso-more-option-item > img {
  width: 24px;
  height: 24px;
  -webkit-margin-end: 8px;
}
.sso-more-option-dropdown .sso-more-option-item > div {
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 160%;
  text-align: left;
}

.divider {
  position: relative;
  border: 0.5px solid var(--neut-300);
  display: flex;
  justify-content: center;
  margin: 32px 0;
}
.divider > span {
  position: absolute;
  top: -10px;
  background-color: #fff;
  color: var(--neut-500);
  text-align: center;
  padding: 0 16px;
}

.divider-line {
  border: 0.5px solid var(--neut-300);
  margin: 24px 0;
  width: 100%;
}
.divider-line.dense {
  margin: 16px 0;
}

.email-hint {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px;
  border-radius: 4px;
  background-color: var(--disabled);
  margin-top: 24px;
  margin-bottom: 16px;
}
.email-hint > span {
  color: var(--disabled-content);
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 1rem;
}
.email-hint > button {
  color: var(--secondary);
  border: none;
  text-decoration: underline;
}
.email-hint > button:focus {
  outline: solid;
  outline-offset: 4px;
  outline-color: var(--secondary);
  outline-width: 2px;
}

.input-wrapper {
  padding: 8px 12px;
  border-radius: 4px;
  border: 1px solid var(--neut-400);
  transition: all 150ms linear;
  display: flex;
  align-items: center;
}
.input-wrapper:focus-within {
  border-color: var(--neutral-focus);
  outline: solid;
  outline-offset: 4px;
  outline-color: var(--secondary);
  outline-width: 2px;
}
.input-wrapper > input {
  width: 100%;
  flex: 1 1 auto;
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 1rem;
  border: none;
  outline: none;
}
.input-wrapper > button {
  border: none;
  background-color: transparent;
  display: flex;
  justify-content: center;
  align-items: center;
}
.input-wrapper > button:focus {
  outline: solid;
  outline-offset: 4px;
  outline-color: var(--secondary);
  outline-width: 2px;
  border-radius: 50%;
}
.input-wrapper > button > img {
  width: 24px;
  height: 24px;
}
.input-wrapper.error {
  border-color: var(--error-focus);
}
.input-error {
  display: block;
  margin-top: 8px;
  color: var(--error-focus);
}
.input-label {
  color: var(--base-content);
  margin-bottom: 8px;
  margin-top: 16px;
}
.input-label > .mandatory,
.checkbox-wrapper label > .mandatory {
  vertical-align: text-top;
  color: var(--error-focus);
  margin-inline-start: 4px;
}

.autocomplete-wrapper {
  position: relative;
}

.autocomplete-popover {
  position: absolute;
  left: 0;
  top: 64px;
  display: none;
  width: 100%;
  background-color: var(--base-100);
  border-radius: 4px;
  box-shadow: 0px 4px 8px 0px rgba(0, 0, 0, 0.1);
  z-index: 10;
  max-height: 200px;
  padding: 1em;
  overflow-y: auto;
}

.autocomplete-popover > li {
  font-family: var(--vs-portal-font);
  font-size: 0.875em;
  font-style: normal;
  font-weight: 400;
  padding: 0.5em 1em;
  line-height: 160%;
  border-radius: 8px;
  background: #fff;
  height: 2.375em;
  color: var(--base-content);
  cursor: pointer;
}

.autocomplete-popover > li:hover {
  background: var(--base-300);
}

.autocomplete-popover > li.focus {
  outline: solid;
  outline-offset: 4px;
  outline-color: var(--secondary);
  outline-width: 2px;
}

.autocomplete-icon {
  position: absolute;
  right: 1em;
  top: 0.7em;
  cursor: pointer;
}

.autocomplete-icon.active {
  transform: rotate(180deg);
}

.autocomplete-hidden-input {
  display: none;
}

.forget-pw-container {
  display: flex;
  align-items: center;
  padding-top: 16px;
}
.forget-pw-container > span {
  color: var(--secondary);
  text-decoration: underline;
  cursor: pointer;
}

.send-email-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.send-email-container > div:last-child {
  display: flex;
  align-items: center;
}
.send-email-container > div:last-child > a {
  color: var(--base-content);
}
.send-email-container > div:last-child > img {
  width: 18px;
  height: 18px;
  margin-inline-end: 8px;
}

.btn-sign-in-up-primary {
  margin-top: 16px;
  padding: 12px 24px;
  border-radius: 8px;
  width: 100%;
  justify-content: center;
}
.btn-sign-in-up-primary > span {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0.02em;
  font-weight: 500;
  font-size: 0.875rem;
}

.btn-sign-in-companion {
  padding: 12px 24px;
  border-radius: 8px;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.btn-sign-in-companion > span {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: 0.02em;
  font-weight: 500;
  font-size: 0.875rem;
}
.btn-sign-in-companion > img {
  margin-inline-end: 4px;
  width: 18px;
  height: 14px;
}

.btn-back {
  padding: 12px 24px;
  margin-bottom: 16px;
  transform: translateX(0%);
}
.btn-back > img {
  width: 18px;
  height: 18px;
  margin-inline-end: 4px;
}

#login_companion {
  position: relative;
}

.companion-qrcode-container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.btn-companion-qrcode-expired {
  border-radius: 8px;
  padding: 8px 18px;
  margin: 24px 24px 0;
}
.btn-companion-qrcode-expired > img {
  width: 18px;
  height: 18px;
  margin-inline-end: 4px;
}

.c-error {
  color: #d0342c !important;
  font-size: 13px;
  margin-top: 6px;
  display: flex;
  align-items: center;
}

.container-mvb-download {
  margin-top: 16px;
}
.container-mvb-download > h6 {
  color: var(--base-content-variant);
  white-space: pre-wrap;
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 0.875rem;
  margin-bottom: 8px;
}

.dl-instruction-block {
  display: flex;
  flex-direction: row;
  align-items: stretch;
}
.dl-instruction-block > div:first-child {
  color: var(--base-content);
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}
.dl-instruction-block > div:first-child > h4 {
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 1.125rem;
}
.dl-instruction-block > div:first-child > div {
  margin-top: 8px;
  font-family: var(--vs-portal-font);
  line-height: 1.6;
  letter-spacing: 0em;
  font-weight: 400;
  font-size: 0.875rem;
}
.dl-instruction-block > .dl-instruction-block-img {
  border-radius: 4px;
  padding: 16px 12px 0;
  background-color: var(--blue-50);
  display: flex;
  justify-content: center;
  height: 140px;
  margin-top: 0;
}
.dl-instruction-block > .dl-instruction-block-img > img {
  width: 140px;
  height: 100%;
}
.dl-instruction-block > .dl-instruction-block-get-app {
  padding: 16px 12px;
}
.dl-instruction-block > .dl-instruction-block-get-app > div {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 140px;
}
.dl-instruction-block > .dl-instruction-block-get-app > div > div {
  padding: 8px;
  border-radius: 4px;
  background-color: var(--base-100);
}
.dl-instruction-block-get-app-btns {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 8px;
}

.dl-instruction-block-get-app-btns a > span {
  border-radius: 4px;
  padding: 8px 16px;
  background-color: var(--neutral);
  display: flex;
  align-items: center;
}
.dl-instruction-block-get-app-btns a:first-of-type {
  margin-bottom: 8px;
}
.dl-instruction-block-get-app-btns a > span > img {
  width: 72px;
  height: 18px;
}

.content-body-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  font-family: var(--vs-portal-font);
}

.container-btns {
  margin-top: 16px;
  padding-top: 16px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.container-btns > button {
  margin-inline-start: 16px;
}

.pw-validate {
  display: flex;
  flex-direction: column;
  margin-top: 24px;
  margin-bottom: 8px;
}
.pw-validate > * {
  padding-top: 4px;
  padding-inline-start: 12px;
  border-inline-start: 4px solid var(--info);
  display: flex;
  align-items: center;
  transition: all 150ms linear;
}
.pw-validate > *.passed {
  border-inline-start-color: var(--success-focus);
}
.pw-validate > div > img {
  width: 16px;
  height: 16px;
  margin-inline-end: 4px;
}

.app-loading {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--neut-1000);
  opacity: 40%;
  z-index: 25;
}
.app-loading-icon-wrapper {
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  z-index: 20;
}
.app-loading-icon {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background-color: transparent;
}
.app-loading-icon > span {
  width: 56px;
  height: 56px;
  background-color: var(--base-300);
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.name-input-wrapper {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
.name-input-wrapper > * {
  display: flex;
  flex-direction: column;
}
.name-input-wrapper > *:first-child > label {
  margin-top: 0;
}
.checkbox-wrapper {
  display: flex;
  align-items: flex-start;
}
.checkbox-wrapper label {
  cursor: pointer;
  text-align: start;
}
.checkbox-wrapper > input[type="checkbox"] {
  flex: none;
  border: 1px solid var(--neut-400);
  border-radius: 4px;
  width: 16px;
  height: 16px;
  padding: 2px;
  margin-inline-end: 12px;
  user-select: none;
  appearance: none;
  cursor: pointer;
}
.checkbox-wrapper > input[type="checkbox"]:focus {
  outline: solid;
  outline-offset: 4px;
  outline-color: var(--secondary);
  outline-width: 2px;
}

.checkbox-wrapper.error > input[type="checkbox"] {
  border-color: var(--error-focus);
}
.checkbox-wrapper > input[type="checkbox"]:checked {
  border-color: var(--neutral-focus);
  accent-color: var(--neutral-focus);
  appearance: auto;
}

[name="otp_code"] {
  height: 0;
  visibility: hidden;
}

.opt-code-wrapper {
  display: flex;
  justify-content: space-between;
}

.opt-code-wrapper > input {
  border: none;
  outline: none;
  background-color: transparent;
  border-bottom: 1px solid #000;
  padding: 18px;
  width: 15%;
  font-size: 2rem;
  text-align: center;
}

.content-footer-otp {
  color: var(--base-content);
}

.content-footer-otp > a {
  text-decoration: underline;
  color: var(--secondary);
}

._popup_desc {
  white-space: pre-wrap;
}

.popup-dialog {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 20;
}
.popup-dialog > div {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 48px);
  margin: auto;
  max-height: 510px;
  overflow: auto;
  border-radius: 16px;
}
.popup-dialog-title {
  color: var(--base-content);
  font-family: var(--vs-portal-font);
  line-height: 1.2;
  letter-spacing: -0.02em;
  font-weight: 700;
  font-size: 1.25rem;
  margin-bottom: 12px;
}
.dl-popup-close {
  position: absolute;
  top: 8px;
  right: 8px;
  padding: 8px;
}
.dl-popup-close > img {
  width: 18px;
  height: 18px;
}

.wrapper-otp-code {
  border-radius: 4px;
  background-color: var(--blue-50);
  padding: 16px;
  display: flex;
  gap: 8px;
  position: relative;
}
.wrapper-otp-code > div {
  flex: 1 1 auto;
  border-radius: 4px;
  background-color: var(--base-200);
  height: 60px;
  padding: 12px 4px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.wrapper-otp-code > div > input {
  width: 100%;
  height: 100%;
  background-color: transparent;
  border: none;
  text-align: center;
}
.wrapper-otp-code > div > input:focus {
  outline: none;
}
.otp-dont-ask-label {
  color: var(--base-content-variant);
}
.otp-footer-action-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
}
.otp-footer-action-wrapper > span {
  cursor: pointer;
  color: var(--secondary);
  text-decoration-line: underline;
}
.otp-hint-wrapper > * {
  margin-top: 8px;
}
.otp-hint-wrapper > .error {
  color: var(--error-focus);
}
.otp-hint-wrapper > .info {
  color: var(--info-focus);
}
.otp-hint-wrapper > .link {
  color: var(--secondary);
  text-decoration-line: underline;
  cursor: pointer;
}
.otp-method-wrapper {
  padding: 0 16px;
  display: flex;
  align-items: center;
  height: 70px;
  cursor: pointer;
  transition: all 0.2s linear;
}
.otp-method-wrapper:hover {
  background-color: var(--base-200);
}
.otp-method-wrapper > * {
  flex: 0 0 auto;
  color: var(--base-content);
}
.otp-method-wrapper > span {
  margin: 0 8px;
  flex: 1 1 auto;
}
.otp-method-wrapper > img {
  width: 24px;
  height: 24px;
}
.otp-method-wrapper.disabled > img {
  color: var(--disabled-content);
}
.otp-method-wrapper.disabled > * {
  color: var(--disabled-content);
  cursor: not-allowed;
}

/* md */
@media (min-width: 768px) {
  .checkbox-wrapper {
    align-items: center;
  }

  .wrapper-otp-code > div {
    padding: 12px 16px;
  }

  .autocomplete-icon {
    position: absolute;
    right: 1em;
    top: 1em;
  }
  .content-container-error > h1 {
    font-size: 3rem;
    margin-bottom: 32px;
  }

  .alert-box {
    padding: 12px 24px;
  }
  .alert-box > img {
    width: 24px;
    height: 24px;
  }
  .alert-box > :not(img) {
    font-size: 1rem;
  }

  .btn-w-icon > img {
    width: 24px;
    height: 18px;
  }

  .header {
    height: 64px;
    padding: 12px 16px;
  }
  .header > img {
    height: 28px;
  }

  .footer > * {
    font-size: 0.875rem;
  }

  .page-container {
    min-height: calc(100vh - 64px);
    margin-top: 64px;
  }

  .content-container,
  .content-container-error {
    max-width: 528px;
  }
  .content-box {
    padding: 32px 40px 40px;
    border-radius: 16px;
  }
  .content-container-msg {
    max-width: 840px;
  }
  .content-box-msg {
    min-height: 500px;
    padding-left: 64px;
    padding-right: 64px;
    padding-top: 70px;
    padding-bottom: 70px;
    justify-content: flex-start;
  }
  .content-box-msg > div {
    align-items: flex-start;
    width: 75%;
  }
  .content-box-msg > div > * {
    text-align: start;
  }
  .content-box-msg > div > h1 {
    font-size: 2rem;
  }
  .content-box-msg > div > h2 {
    font-size: 1rem;
  }
  .content-box-msg > div > button {
    padding: 16px 40px;
    letter-spacing: 0em;
    font-size: 1rem;
    margin-top: 32px;
  }

  .content-footer {
    flex-direction: row;
    justify-content: space-between;
  }

  .page-title-box {
    padding: 4px 0 8px;
    margin-bottom: 32px;
  }
  .page-title-box > h1 {
    font-size: 2rem;
  }
  .page-title-box > h1 > img {
    width: 39px;
    height: 32px;
  }
  .page-title-box > h2 {
    margin-top: 8px;
    font-size: 1rem;
  }
  .qrcode-login-title-box {
    margin-bottom: 0px;
    margin-top: 32px;
  }

  .sso-btns button {
    padding: 12px 20px;
    border-radius: 30px;
  }

  .divider {
    margin: 40px 0;
  }

  .divider-line {
    margin: 32px 0;
  }
  .divider-line.dense {
    margin: 16px 0;
  }

  .input-wrapper {
    padding: 16px;
  }

  .email-hint {
    margin-top: 32px;
    padding: 16px;
  }

  .link-skip-to-main > button {
    padding: 16px 40px;
    font-size: 1rem;
  }
  .btn-sign-in-up-primary {
    padding: 16px 40px;
  }
  .btn-sign-in-up-primary > span {
    font-size: 1rem;
  }

  .btn-sign-in-companion {
    padding: 16px 40px;
  }
  .btn-sign-in-companion > span {
    font-size: 1rem;
  }

  .btn-companion-qrcode-expired {
    padding: 16px 40px;
    margin-top: 32px;
  }

  .container-mvb-download > h6 {
    font-size: 1rem;
  }

  .btn-secondary-page {
    padding: 16px 40px;
    letter-spacing: 0em;
    font-size: 1rem;
  }

  .content-box-msg > span:first-of-type {
    height: 110px;
  }
  .content-box-msg > span:last-of-type {
    height: 365px;
  }
  .content-box-msg-bg {
    background-size: auto 22%, auto 73%;
  }

  .name-input-wrapper {
    flex-direction: row;
    justify-content: space-between;
  }
  .name-input-wrapper > * {
    width: 192px;
  }
  .name-input-wrapper > * > label {
    margin-top: 0;
  }

  .pw-validate {
    margin-top: 16px;
    margin-bottom: 0;
  }

  .popup-dialog > div {
    max-width: 500px;
  }

  .popup-dialog-title {
    font-size: 2rem;
    margin-bottom: 16px;
  }

  .dl-instruction-block-get-app-btns {
    flex-direction: row;
  }
  .dl-instruction-block-get-app-btns a:first-of-type {
    margin-bottom: 0px;
    margin-inline-end: 8px;
  }
  .dl-popup-close {
    top: 16px;
    right: 16px;
  }

  .text-neut-600 {
    color: var(--neut-600);
  }

  .tab {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    gap: 0.5em;
  }

  .tab > div {
    display: flex;
    align-items: center;
    width: 48px;
    height: 1px;
    background-color: var(--neut-300);
  }

  .tab > div.active {
    background-color: var(--red-500);
  }
}

/* lg */
@media (min-width: 1024px) {
  .header {
    padding: 12px 24px;
  }

  .footer {
    padding: 24px 0;
    margin-top: 56px;
  }

  .btn-back {
    position: absolute;
    left: 0;
    top: 0;
    transform: translateX(-100%);
  }
}

/* xl */
@media (min-width: 1280px) {
  .header {
    padding: 12px 32px;
  }
}

.hidden {
  display: none;
}

.non-vis {
  visibility: hidden;
}

.opac-2 {
  opacity: 0.2;
}
