@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300..700&display=swap";
@import "https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap";

/* ../connect-react/src/css/light.css */
.light {
  --cb-color-primary: rgb(79 91 146);
  --cb-color-surface-tint: rgb(79 91 146);
  --cb-color-on-primary: rgb(255 255 255);
  --cb-color-primary-container: rgb(221 225 255);
  --cb-color-on-primary-container: rgb(7 22 75);
  --cb-color-secondary: rgb(90 93 114);
  --cb-color-on-secondary: rgb(255 255 255);
  --cb-color-secondary-container: rgb(223 225 249);
  --cb-color-on-secondary-container: rgb(23 27 44);
  --cb-color-tertiary: rgb(118 84 110);
  --cb-color-on-tertiary: rgb(255 255 255);
  --cb-color-tertiary-container: rgb(255 215 243);
  --cb-color-on-tertiary-container: rgb(44 18 41);
  --cb-color-success: rgb(128, 184, 22);
  --cb-color-error: rgb(186 26 26);
  --cb-color-on-error: rgb(255 255 255);
  --cb-color-error-container: rgb(255 218 214);
  --cb-color-on-error-container: rgb(65 0 2);
  --cb-color-background: rgb(251 248 255);
  --cb-color-on-background: rgb(27 27 33);
  --cb-color-surface: rgb(251 248 255);
  --cb-color-on-surface: rgb(27 27 33);
  --cb-color-surface-variant: rgb(226 225 236);
  --cb-color-on-surface-variant: rgb(69 70 79);
  --cb-color-outline: rgb(118 118 128);
  --cb-color-outline-variant: rgb(198 197 208);
  --cb-color-shadow: rgb(0 0 0);
  --cb-color-scrim: rgb(0 0 0);
  --cb-color-inverse-surface: rgb(47 48 54);
  --cb-color-inverse-on-surface: rgb(242 240 247);
  --cb-color-inverse-primary: rgb(184 196 255);
  --cb-color-primary-fixed: rgb(221 225 255);
  --cb-color-on-primary-fixed: rgb(7 22 75);
  --cb-color-primary-fixed-dim: rgb(184 196 255);
  --cb-color-on-primary-fixed-variant: rgb(55 67 121);
  --cb-color-secondary-fixed: rgb(223 225 249);
  --cb-color-on-secondary-fixed: rgb(23 27 44);
  --cb-color-secondary-fixed-dim: rgb(194 197 221);
  --cb-color-on-secondary-fixed-variant: rgb(66 70 89);
  --cb-color-tertiary-fixed: rgb(255 215 243);
  --cb-color-on-tertiary-fixed: rgb(44 18 41);
  --cb-color-tertiary-fixed-dim: rgb(228 186 217);
  --cb-color-on-tertiary-fixed-variant: rgb(92 61 86);
  --cb-color-surface-dim: rgb(219 217 224);
  --cb-color-surface-bright: rgb(251 248 255);
  --cb-color-surface-container-lowest: rgb(255 255 255);
  --cb-color-surface-container-low: rgb(245 242 250);
  --cb-color-surface-container: rgb(239 237 244);
  --cb-color-surface-container-high: rgb(233 231 239);
  --cb-color-surface-container-highest: rgb(227 225 233);
}

/* ../connect-react/src/css/dark.css */
.dark {
  --cb-color-primary: rgb(184 196 255);
  --cb-color-surface-tint: rgb(184 196 255);
  --cb-color-on-primary: rgb(32 44 97);
  --cb-color-primary-container: rgb(55 67 121);
  --cb-color-on-primary-container: rgb(221 225 255);
  --cb-color-secondary: rgb(194 197 221);
  --cb-color-on-secondary: rgb(44 47 66);
  --cb-color-secondary-container: rgb(66 70 89);
  --cb-color-on-secondary-container: rgb(223 225 249);
  --cb-color-tertiary: rgb(228 186 217);
  --cb-color-on-tertiary: rgb(68 39 63);
  --cb-color-tertiary-container: rgb(92 61 86);
  --cb-color-on-tertiary-container: rgb(255 215 243);
  --cb-color-success: rgb(128, 184, 22);
  --cb-color-error: rgb(255 180 171);
  --cb-color-on-error: rgb(105 0 5);
  --cb-color-error-container: rgb(147 0 10);
  --cb-color-on-error-container: rgb(255 218 214);
  --cb-color-background: rgb(18 19 24);
  --cb-color-on-background: rgb(227 225 233);
  --cb-color-surface: rgb(18 19 24);
  --cb-color-on-surface: rgb(227 225 233);
  --cb-color-surface-variant: rgb(69 70 79);
  --cb-color-on-surface-variant: rgb(198 197 208);
  --cb-color-outline: rgb(144 144 154);
  --cb-color-outline-variant: rgb(69 70 79);
  --cb-color-shadow: rgb(0 0 0);
  --cb-color-scrim: rgb(0 0 0);
  --cb-color-inverse-surface: rgb(227 225 233);
  --cb-color-inverse-on-surface: rgb(47 48 54);
  --cb-color-inverse-primary: rgb(79 91 146);
  --cb-color-primary-fixed: rgb(221 225 255);
  --cb-color-on-primary-fixed: rgb(7 22 75);
  --cb-color-primary-fixed-dim: rgb(184 196 255);
  --cb-color-on-primary-fixed-variant: rgb(55 67 121);
  --cb-color-secondary-fixed: rgb(223 225 249);
  --cb-color-on-secondary-fixed: rgb(23 27 44);
  --cb-color-secondary-fixed-dim: rgb(194 197 221);
  --cb-color-on-secondary-fixed-variant: rgb(66 70 89);
  --cb-color-tertiary-fixed: rgb(255 215 243);
  --cb-color-on-tertiary-fixed: rgb(44 18 41);
  --cb-color-tertiary-fixed-dim: rgb(228 186 217);
  --cb-color-on-tertiary-fixed-variant: rgb(92 61 86);
  --cb-color-surface-dim: rgb(18 19 24);
  --cb-color-surface-bright: rgb(56 57 63);
  --cb-color-surface-container-lowest: rgb(13 14 19);
  --cb-color-surface-container-low: rgb(27 27 33);
  --cb-color-surface-container: rgb(31 31 37);
  --cb-color-surface-container-high: rgb(41 42 47);
  --cb-color-surface-container-highest: rgb(52 52 58);
}

/* ../connect-react/src/css/shared.css */
:root {
  --cb-font-family-primary: "Space Grotesk", sans-serif;
  --cb-font-family-secondary: "Inter", sans-serif;
  --cb-border-radius: 0rem;
}
.cb-highlight {
  .cb-connect-container {
    outline: 2px solid red;
    outline-offset: 5px;
  }
}
.cb-h2 {
  font-family: var(--cb-font-family-primary);
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
}
.cb-h3 {
  font-family: var(--cb-font-family-primary);
  font-size: 1rem;
  margin-bottom: 0.5rem;
}
.cb-p {
  font-family: var(--cb-font-family-secondary);
  font-size: 1rem;
  margin-bottom: 0.5rem;
}
.cb-divider {
  height: 1rem;
}
.cb-span {
  font-family: var(--cb-font-family-secondary);
  font-size: 1rem;
}
.cb-bold {
  font-weight: bold;
}
.cb-link-button {
  cursor: pointer;
  width: 100%;
  text-decoration: underline;
}
.cb-connect-container {
  font-family: var(--cb-font-family-primary);
  background-color: var(--cb-color-surface);
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  text-align: left;
  width: 100%;
}
button.cb-primary-button {
  padding: 0.75rem 1.5rem;
  color: var(--cb-color-on-primary);
  background-color: var(--cb-color-primary);
  border-radius: var(--cb-border-radius);
  border: none;
  cursor: pointer;
  box-sizing: border-box;
  font-family: var(--cb-font-family-primary);
  text-decoration: none;
}
.cb-primary-button:hover,
.cb-primary-button:focus,
.cb-primary-button:active {
  border: none;
  opacity: 92%;
}
.cb-primary-button:disabled {
  opacity: 84%;
}
button:hover {
  cursor: pointer;
}
button.cb-secondary-button {
  padding: 0.75rem 1.5rem;
  color: var(--cb-color-on-secondary);
  background-color: var(--cb-color-secondary);
  border-radius: var(--cb-border-radius);
  border: none;
  cursor: pointer;
  box-sizing: border-box;
  font-family: var(--cb-font-family-primary);
}
.cb-secondary-button:hover,
.cb-secondary-button:focus,
.cb-secondary-button:active {
  border: none;
  opacity: 92%;
}
button.cb-outline-button {
  padding: 0.75rem 1.5rem;
  color: var(--cb-color-primary);
  background-color: transparent;
  border-radius: var(--cb-border-radius);
  border: 1px solid var(--cb-color-primary);
  cursor: pointer;
  box-sizing: border-box;
  font-family: var(--cb-font-family-primary);
}
.cb-input {
  flex-grow: 1;
  border-radius: var(--cb-border-radius);
  color: var(--cb-color-tertiary);
  border: 1px solid var(--cb-color-outline);
  padding: 0.75rem 0.5rem;
  justify-content: center;
  box-sizing: border-box;
  font-family: var(--cb-font-family-secondary);
}
.cb-input:focus {
  outline: none;
  border: 1px solid var(--cb-color-primary);
}
.cb-input:disabled {
  background-color: var(--cb-input-disabled-color);
}
.cb-input-error {
  border: 1px solid var(--cb-color-error);
}
.cb-input-field {
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin-bottom: 0.75rem;
}
.cb-checkbox-input-field {
  margin-bottom: 0.75rem;
}
.cb-checkbox-input-field input {
  margin-right: 0.5rem;
}
.cb-input-label {
  font-family: var(--cb-font-family-secondary);
  margin: 0.25rem 0.5rem;
}
.cb-input-label-text {
}
.cb-notification-container {
  display: flex;
  padding: 0.5rem 1rem;
  background: var(--cb-color-secondary-container);
  color: var(--cb-color-on-secondary-container);
  border-radius: 0.7rem;
}
.cb-notification-icon {
  width: 20px;
  margin-right: 0.25rem;
  fill: var(--cb-color-on-secondary-container);
}
.cb-notification-text {
  font-size: 0.8rem;
  display: flex;
  align-items: center;
}
.cb-error-notification {
  width: 100%;
  box-sizing: border-box;
  background-color: var(--cb-color-error-container);
  color: var(--cb-color-on-error-container);
  border-radius: var(--cb-border-radius);
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}
.loader {
  width: 0.75rem;
  height: 0.75rem;
  border: 2px solid #fff;
  border-radius: 50%;
  display: inline-block;
  box-sizing: content-box;
  animation: rotation 1s linear infinite;
  vertical-align: middle;
}
.loader-primary {
  border-top-color: var(--cb-color-primary);
  border-bottom-color: transparent;
}
.loader-on-primary {
  border-color: var(--cb-color-on-primary);
  border-bottom-color: transparent;
}
.button-loading-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: inherit;
  border-radius: inherit;
  border: inherit;
}
@keyframes rotation {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.cb-connect-custom-style div.cb-connect-append-cta {
  border-top: none;
}
.cb-connect-custom-style .cb-login-error-soft-container,
.cb-connect-custom-style .cb-login-error-hard-container {
  align-items: normal;
  width: 100%;
}
.cb-connect-custom-style button.cb-login-hybrid-button {
  width: 100%;
}
.cb-connect-custom-style button.cb-login-error-soft-button,
.cb-connect-custom-style button.cb-login-error-hard-button,
.cb-connect-custom-style button.cb-login-error-hard-fallback {
  width: 100%;
}
#passkey-append .cb-connect-custom-style {
  display: flex;
  justify-content: center;
}

/* ../connect-react/src/css/login.css */
.cb-connect-login {
  max-width: 400px;
  container-type: inline-size;
}
.cb-login-hybrid-container {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.cb-login-hybrid-container .cb-p,
.cb-login-hybrid-container .cb-link-button {
  text-align: center;
}
.cb-login-init-signup {
  margin-top: 2rem;
}
.cb-login-header {
  text-align: center;
}
.cb-login-error-soft-icons,
.cb-login-error-hard-icons {
  margin: 1.5rem 0;
  display: flex;
  justify-content: center;
}
.cb-login-error-soft-text,
.cb-login-error-hard-text {
  margin: 1rem 0;
  text-align: center;
}
.cb-login-error-soft-fallback {
  margin-top: 1rem;
  text-align: center;
  color: var(--cb-color-secondary);
}
.cb-login-error-soft-button,
.cb-login-error-hard-button {
  width: 100%;
  background: var(--cb-color-primary);
}
.cb-login-error-hard-icons > * {
  width: 80px;
}
.cb-login-error-hard-fallback {
  margin-top: 1rem;
  width: 100%;
}
.cb-login-error-hard-button-help {
  color: var(--cb-color-secondary);
}
.cb-switch {
  margin-top: 1rem;
}
.cb-login-hybrid-icons {
  margin: 1rem 0;
  padding: 2rem 0;
  display: flex;
  justify-content: center;
  color: var(--cb-color-on-primary-container);
  border-radius: var(--cb-border-radius);
}
.cb-login-hybrid-icons {
  gap: 2rem;
}
.cb-login-hybrid-icons > * {
  width: 180px;
}
.cb-login-hybrid-cta {
  margin: 1rem 0rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  width: 100%;
}
.cb-login-loader-container {
  width: 100%;
  display: flex;
  justify-content: center;
  padding-top: 1rem;
  padding-bottom: 1rem;
}
.cb-login-loader {
  width: 50px;
  height: 50px;
}
.cb-passkey-button {
  padding: 1rem;
  background-color: white;
  color: var(--cb-color-on-primary);
  border-radius: var(--cb-border-radius);
  border: 1px solid var(--cb-color-outline);
  font-family: var(--cb-font-family-primary);
  width: 100%;
  display: flex;
  justify-items: between;
  align-items: center;
  gap: 1rem;
}
.cb-passkey-button-icon {
  width: 25px;
  height: 25px;
  color: black;
}
.cb-passkey-button-content {
  flex: 1;
  text-align: left;
}
.cb-passkey-button-title {
  font-weight: bold;
  font-size: 0.8rem;
  color: black;
}
.cb-passkey-button-subtitle {
  color: var(--cb-color-primary);
  font-size: 0.8rem;
}
.cb-passkey-button-arrow {
  width: 9px;
  color: black;
}

/* ../connect-react/src/css/modal.css */
.cb-modal-outer {
  z-index: 99999;
  top: 0px;
  left: 0px;
  display: flex;
  position: fixed;
  align-items: center;
  justify-content: center;
  height: 100vh;
  width: 100vw;
}
.cb-modal-outer-background {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: black;
  opacity: 0.2;
}
.cb-modal-outer-content {
  position: relative;
  background-color: var(--cb-color-surface);
  border-radius: var(--cb-border-radius);
  padding: 2rem;
  border: 1px solid var(--cb-color-outline);
  width: 100%;
  max-width: 600px;
  margin: 1rem;
}
.cb-modal {
  text-align: left;
  gap: 1rem;
}
.cb-modal-cta {
  width: 100%;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 2rem;
}
.cb-modal-exit-icon {
  width: 18px;
  height: 18px;
  color: var(--cb-color-primary);
  cursor: pointer;
  margin-bottom: 0.5rem;
}
.cb-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
.cb-modal-content {
  margin: 1rem 0rem;
}

/* ../connect-react/src/css/append.css */
.cb-connect-append {
  text-align: center;
  max-width: 400px;
}
.cb-connect-append-border {
  padding: 2rem 1rem;
}
.cb-append-benefits-container {
  text-align: left;
}
.cb-connect-append-icon {
  justify-items: center;
  padding: 1rem 0;
}
.cb-passkey-info-list-item {
  display: flex;
  margin: 0.5rem 0;
  width: 100%;
  align-items: center;
}
.cb-passkey-info-list-item-icon {
  width: 75px;
  margin-right: 0.25rem;
  flex: 0 0 60px;
  padding: 0.5rem;
  color: var(--cb-color-primary);
}
.cb-passkey-info-list-item-text {
  flex: 1;
}
.cb-passkey-info-list-item-header {
  color: var(--cb-color-primary);
}
.cb-append-success-container {
  margin: 1rem 0;
}
.cb-append-success-header {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.1rem;
}
.cb-append-success-header-icon {
  height: 2rem;
  width: 2rem;
  margin-right: 0.25rem;
  color: var(--cb-color-primary);
}
.cb-append-success-icons {
  margin: 2rem 0 1rem 0;
  display: flex;
  justify-content: center;
  color: var(--cb-color-on-primary-container);
}
.cb-append-success-icons > * {
  width: 80px;
}
.cb-append-success-cta {
  margin-top: 1rem;
  display: flex;
  flex-direction: column;
  padding: 0 1rem;
}
.cb-append-success-cta-continue {
}
.cb-append-success-message-icon {
  height: 1.5rem;
  display: inline-block;
}
.cb-append-info-list {
  margin: 1rem 0;
}
.cb-connect-append-cta {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 2rem 1rem 0 1rem;
}
.cb-append-icon {
  width: 10px;
}
.cb-append-skip {
  width: fit-content;
}
.cb-append-skip-container {
  color: var(--cb-color-secondary);
  margin-top: 1rem;
  width: fit-content;
  padding: 0;
  display: flex;
  justify-content: center;
}
.cb-append-after-hybrid-login-icons,
.cb-append-after-error-icons {
  margin: 1rem 0;
  display: flex;
  justify-content: center;
  color: var(--cb-color-primary);
}
.cb-append-after-hybrid-login-icons > *,
.cb-append-after-error-icons > * {
  width: 120px;
  margin: 1rem 0rem;
}
.cb-append-after-hybrid-login-button,
.cb-append-after-error-button,
.cb-append-after-hybrid-login-fallback,
.cb-append-after-error-fallback {
  text-align: left;
}
.cb-append-after-hybrid-login-content {
  margin-top: 1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.cb-append-after-hybrid-login-content,
.cb-checkbox-input-field {
  .cb-p {
    margin-bottom: 0;
  }
}
.cb-checkbox-input-field {
  margin-top: 0.5rem;
  label {
    display: flex;
    align-items: center;
  }
}
.cb-append-after-hybrid-login-lock-icon {
  width: 24px;
  flex-shrink: 0;
}
.cb-append-after-hybrid-login-cta,
.cb-append-after-error-cta {
  margin: 1rem 0rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* ../connect-react/src/css/passkey-list.css */
.cb-connect-passkey-list {
  display: flex;
  flex-direction: column;
  align-items: end;
}
.cb-passkey-list-item {
  width: 100%;
  display: flex;
  border-radius: var(--cb-border-radius);
  border: 1px solid var(--cb-color-outline);
  gap: 2rem;
  justify-content: space-between;
  align-items: start;
  padding: 1rem 0;
  box-sizing: border-box;
}
.cb-modal {
  .cb-passkey-list-item {
    background: var(--cb-color-primary-container);
    padding: 1rem;
  }
}
.cb-passkey-list-item-icon-container {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: black;
  box-sizing: border-box;
  margin-top: 2px;
}
.cb-passkey-list-item-icon {
  color: black;
  width: 100%;
}
.cb-passkey-list-item-delete-icon {
  margin-top: 5px;
  margin-right: 5px;
  width: 12px;
  color: var(--cb-color-secondary);
}
.cb-passkey-list-item-content {
  flex: 1;
}
.cb-passkey-list-item-title {
  color: var(--cb-color-primary);
  font-size: 1.25rem;
  font-family: var(--cb-font-family-secondary);
  margin-bottom: 0.5rem;
}
.cb-passkey-list-item-details {
  color: var(--cb-color-secondary);
  font-size: 0.875rem;
}
.cb-tag {
  background-color: var(--cb-color-secondary-container);
  color: var(--cb-color-on-secondary-container);
  border-radius: var(--cb-border-radius);
  padding: 2px 4px;
  display: flex;
  gap: 4px;
  font-size: 0.625rem;
  font-weight: bold;
}
.cb-passkey-list-item-tag-icon {
  width: 10px;
}
.cb-passkey-list-item-tags {
  display: flex;
  width: 100%;
  gap: 2px;
  flex-wrap: wrap;
}
.cb-passkey-list-item-header {
  display: flex;
  text-align: left;
  align-items: start;
  margin-bottom: 0.5rem;
  flex-direction: column;
  gap: 2px;
}
.cb-passkey-list-append-button {
  background-color: var(--cb-color-primary);
  border-radius: var(--cb-border-radius);
  color: var(--cb-color-on-primary);
  display: flex;
  gap: 1rem;
  margin-top: 2rem;
  align-items: center;
  padding: 6px 10px;
}
.cb-passkey-list-append-button .loader {
  height: 15px;
  width: 15px;
}
.cb-passkey-list-append-icon {
  width: 10px;
}
.cb-passkey-list-loader-container {
  padding: 44px 0;
  width: 100%;
  min-height: fit-content;
  display: flex;
  justify-content: center;
  align-items: center;
}
.cb-passkey-list-loader {
  width: 100px;
  height: 100px;
}
.cb-passkey-list-empty {
  width: 100%;
  color: var(--cb-color-on-primary-container);
  padding: 32px 44px;
  font-size: 1rem;
  min-height: fit-content;
  display: flex;
  align-items: center;
  box-sizing: border-box;
}
@media screen and (max-width: 600px) {
  .cb-passkey-list-item {
    gap: 1rem;
  }
}

/* ../connect-react/src/css/demo.css */
.cb-demo-screen-container {
  margin: 2rem 0;
}
.cb-demo-screen-box {
  border: 1px solid #ccc;
  border-radius: 4px;
  padding: 1rem;
  margin: 1rem 0;
}
.description-headline {
  font-size: 1.25rem;
  font-weight: bold;
}
.demo-controls-item input {
  margin-right: 2rem;
  margin-top: 0.2rem;
}

/* ../connect-react/src/index.css */
