/* SIMULATOR UPDATED */
.simulator-container {
  display: grid;
  grid-template-rows: min-content 1fr min-content;
  row-gap: var(--gap-small);
  max-width: var(--width-simulator);
  height: 1050px;
  background-color: var(--color-white);
  padding: var(--padding-simulator);
  margin: var(--margin-simulator);
  border-radius: var(--radius-default);
  box-shadow: var(--shadow-medium);
  text-align: center;
}

.simulator-header {
  grid-row: 1;
  display: grid;
  row-gap: var(--gap-normal);
}

.company-logo {
  padding: 0;
}

/* Class needed for the inactive logo-link element on start page */
.link-disabled {
  cursor: auto;
}

/* STEP PROGRESS BAR */
.progress-steps {
  justify-content: center;
  margin-top: var(--margin-list);
  margin-bottom: var(--margin-small);
}

.progress-circle {
  display: flex;
  flex-direction: column;
  flex: 1;
  align-items: center;
  gap: var(--gap-small);
  color: var(--color-primary);
  font-family: var(--font-alaska);
  font-size: var(--font-progress-steps);
  position: relative;
}

.progress-circle:before {
  content: '';
  width: var(--size-progress-circle);
  height: var(--size-progress-circle);
  border-radius: var(--radius-circle);
  align-self: center;
  background: currentColor;
}

.progress-circle--active:before {
  box-shadow: var(--shadow-circle--active);
}

.progress-circle--inactive:before {
  border: var(--border-circle--inactive);
}

.progress-circle--inactive {
  color: var(--color-circle--inactive);
}

.progress-circle--pending:before {
  box-shadow: var(--shadow-circle--pending);
}

.progress-circle--pending {
  color: var(--color-circle--pending);
}

.progress-circle:after {
  content: '';
  height: 0.1rem;
  width: calc(100% - 4em);
  background: var(--color-circle--inactive);
  position: absolute;
  top: 1.1em;
  left: calc(50% + 2em);
}

.progress-circle:last-child:after {
  content: none;
}

.progress-circle--completed:after {
  background: var(--color-primary);
}

.progress-circle--check:after {
  background: linear-gradient(to right, var(--color-primary) 40%,
  var(--color-circle--pending) 80%);
}

/* CREDIT LINE CONTENT */
.simulator-content {
  grid-row: 2;
  justify-items: center;
  padding-top: var(--padding-normal);
}

.simulator-heading {
  font-size: var(--font-simulator-heading);
  margin-bottom: calc(var(--margin-normal) / 2);
  line-height: var(--lheight-subheading);
}

.simulator-text {
  color: var(--color-text-complementary);
  hyphens: none;
}

/* FIGMA CIRCLES */
.figma-graphic-wrapper {
  width: 100%;
  display: flex;
  justify-content: center;
  position: relative;
  height: var(--size-graphic-wrapper);
  margin: var(--margin-default) 0;
}

/* Class needed for positioning graphic wrapper on start page */
.wrapper-start-margin {
  margin: 2rem 0;
}

.simulator-circle, .dynamic-value-display {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.simulator-circle {
  transform: translate(-50%, -50%) matrix(-1, 0, 0, 1, 0, 0);
  border-radius: var(--radius-circle);
}

.outer-circle {
  width: var(--size-simulator-circle--outer);
  height: var(--size-simulator-circle--outer);
}

.outer-circle--positive {
 background: var(--color-simulator-positive);
}

.outer-circle--negative {
  background: var(--color-simulator-negative);
}

.inner-circle {
  width: var(--size-simulator-circle--inner);
  height: var(--size-simulator-circle--inner);
  background: var(--color-secondary);
}

.inner-circle--positive {
  box-shadow: var(--shadow-simulator-positive);
}

.inner-circle--negative {
  box-shadow: var(--shadow-simulator-negative);
}

.dynamic-value-display {
  font-family: var(--font-alaska);
  font-size: var(--font-text-default);
  line-height: var(--lheight-subheading);
  color: var(--color-white);
}

.dynamic-value-display--positive {
  font-weight: var(--weight-bold);
}

.dynamic-value-display--negative {
  font-weight: var(--weight-medium);
  font-size: var(--font-default);
  line-height: var(--lheight-body);
  padding-bottom: calc(var(--padding-xsmall) * 2);
}

/* CTA BUTTONS */
.simulator-btn:link, .simulator-btn:visited, .simulator-email-container-button,
button.simulator-btn {
  display: inline-block;
  text-decoration: none;
  font-size: var(--font-text-btn);
  font-weight: var(--weight-light);
  padding: var(--padding-simulator-btn);
  border-radius: var(--radius-large);
  border: var(--border-transparent);
  cursor: pointer;
  font-family: var(--font-alaska);
  transition: var(--transition-default);
  margin-bottom: var(--margin-list);
}

.simulator-btn--primary, button.simulator-btn--primary {
  background-color: var(--color-primary);
  color: var(--color-white);
}

button.simulator-btn--primary, .simulator-email-container-button {
  min-height: var(--height-simulator-button);
}

.simulator-btn--primary:hover, .simulator-btn--primary:active {
  background-color: var(--color-primary-dark);
}

.simulator-btn--secondary {
  background-color: var(--color-light-grey--2);
  color: var(--color-text-complementary);
}

.simulator-btn--secondary:hover, .simulator-btn--secondary:active {
  background-color: var(--color-light-grey--3);
  color: var(--color-white);
}

/* FORM */
.form-input--simulator {
  width: 100%;
  height: var(--input-field-height);
}

.form--inner-titlebox {
  margin-bottom: calc(var(--margin-normal) - 0.5rem);
}

.simulator-financial-fields {
  display: flex;
  flex-direction: column;
  background: var(--color-light-grey);
  border-radius: calc(var(--radius-default) - 1rem);
  width: 100%;
  padding: calc(var(--padding-small) * 2);
  gap: var(--gap-xsmall);
}

.form-field {
  margin-bottom: calc(var(--margin-normal) / 2);
}

.form-field:last-of-type {
  margin-bottom: var(--margin-default);
}

.form-container-select {
  width: 100%;
  height: var(--input-field-height);
  color: var(--color-text-complementary);
  background-color: var(--color-white);
  font-size: inherit;
  font-family: inherit;
  cursor: pointer;
  padding: var(--padding-small) calc(var(--padding-small) + 0.6rem);
  border-radius: var(--radius-small);
  border: var(--border-default);
  transition: var(--transition-default);
}

.form-container-select:active, .form-container-select:focus, .form-container-select:hover {
  outline: none;
  border: var(--border-hover);
  box-shadow: var(--shadow-light);
}

.form-field label {
  display: flex;
  justify-content: flex-start;
  gap: var(--gap-xsmall);
  font-weight: var(--weight-medium);
  margin-bottom: var(--margin-form-label);
  color: var(--color-text-complementary);
}

.simulator-result-title--positive {
  display: flex;
  gap: var(--gap-small);
  justify-content: center;
  margin-left: calc(var(--margin-negative) * 2);
}

.simulator-result-title img {
  margin-bottom: var(--margin-default);
}

.simulator-result {
  display: grid;
  justify-content: center;
  margin: 0 0 var(--margin-default);
}

.hidden {
  display: none;
  color: var(--color-error);
}

/*TOOLTIP */
.tooltip-container {
  position: relative;
}

.tooltip-container i {
  cursor: pointer;
}

.tooltip-text {
  visibility: hidden;
  width: var(--width-tooltip);
  color: var(--color-white);
  background-color: var(--color-background-tooltip);
  text-align: center;
  border-radius: var(--radius-small);
  padding: var(--padding-tooltip);
  position: absolute;
  bottom: 125%;
  left: 50%;
  transform: translateX(-50%);
  opacity: 0;
  transition: opacity 0.3s ease;
  font-size: inherit;
}

.tooltip-container:hover .tooltip-text {
  visibility: visible;
  opacity: 1;
}

/* EMAIL INPUT */
.simulator-email-container {
  display: grid;
  align-content: center;
  background: var(--color-light-grey);
  border-radius: var(--radius-default);
  padding: var(--padding-simulator-email);
  min-height: var(--height-simulator-email);
}

.simulator-email-container-heading {
  font-size: var(--font-text-default);
  color: var(--color-secondary);
  margin-bottom: calc(var(--margin-default) + 0.5rem);
}

.simulator-email-container-button {
  background: var(--color-background-complementary);
  color: var(--color-white);
}

.simulator-email-container-button:hover, .simulator-email-container-button:focus {
  background-color: var(--color-background-complementary--dark);
  cursor: pointer;
  color: var(--color-primary-light);
}

.simulator-form-input--email {
  padding: var(--padding-small) var(--padding-normal);
  border: var(--border-hover);
  border-radius: var(--radius-large);
  margin-bottom: var(--margin-small);
}

input.simulator-form-input--email:focus {
  outline: none;
  background-color: var(--color-subheading-alpha);
}

input.simulator-form-input--email:focus::placeholder {
  color: var(--color-subheading);
}

/* Disabled state after email was sent */
.simulator-form-input--email:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  color: black;
  font-weight: bold;
}

.simulator-email-container-button:hover:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* CONTACT LINKS */
.simulator-contact {
  grid-row: 3;
  width: 100%;
  display: flex;
  gap: var(--gap-medium);
  justify-content: center;
  border-top: var(--border-default);
  padding-top: calc(var(--padding-normal) / 2);
}

.simulator-contact > * {
  margin-top: var(--margin-negative-small);
}

.simulator-contact a {
  padding: var(--padding-small);
}

.simulator-contact a span {
  border-bottom: var(--border-transparent);
  padding-bottom: var(--padding-xsmall);
  transition: var(--transition-default);
}

.simulator-contact a span:hover {
  color: var(--color-primary-dark);
  border-bottom-color: currentColor;
}

.simulator-contact img {
  height: var(--size-icon-simulator);
  width: var(--size-icon-simulator);
}

/* Class needed for hiding contact section's top border on result page */
.border-transparent {
  border-top: var(--border-transparent);
}

/* MESSAGES */
.email-success-message {
  color: var(--color-primary-dark);
}

.email-error-message {
  color: var(--color-error);
}

/* Responsive design */
@media only screen and (max-width: 70em) {
  .simulator-container {
    height: 1050px;
  }

  .simulator-heading {
    hyphens: none;
  }
}

@media only screen and (max-width: 56.25em) {
  .simulator-container {
    margin: 4.2rem 8rem;
    padding: 5rem;
    height: 1200px;
  }

  .simulator-heading {
    hyphens: none;
  }
}

@media only screen and (max-width: 43.75em) {
  .simulator-container {
    margin: 4.2rem 6rem;
    height: 1200px;
  }

  .simulator-financial-fields {
    width: 110%;
  }

  .form-field:not(:last-of-type) {
    margin-bottom: var(--margin-small);
  }

  .simulator-text {
    hyphens: auto;
  }

  .simulator-heading {
    hyphens: none;
  }
}

@media only screen and (max-width: 37.5em) {
  .simulator-contact {
    display: block;
  }

  .simulator-contact > * {
    justify-content: center;
  }

  .simulator-contact div:last-of-type {
    margin-left: -1rem;
  }

  .simulator-heading {
    hyphens: none;
  }
}

@media only screen and (max-width: 34.375em) {
  .simulator-container {
    margin: 4.2rem 2rem;
  }

  .tooltip-text {
    max-width: 15rem;
    font-size: var(--font-default);
  }

  .simulator-heading {
    hyphens: none;
  }
}

@media only screen and (max-width: 29.375em) {
  .simulator-container {
    padding: 5rem 3rem;
    height: 1250px;
  }

  .simulator-heading {
    hyphens: none;
  }
}

@media only screen and (max-width: 26.25em) {
  .simulator-container {
    margin: 4.2rem 1rem;
    padding: 5rem 1.5rem;
    height: 1400px;
  }

  .simulator-heading {
    hyphens: none;
  }

  .figma-graphic-wrapper {
    margin: var(--margin-small) 0;
    width: 22rem;
  }

  .wrapper-start-margin {
    margin: 5rem 0;
  }

  .outer-circle {
    width: 18rem;
    height: 18rem;
  }

  .inner-circle {
    width: 12rem;
    height: 12rem;
  }

  .dynamic-value-display {
    font-size: var(--font-default);
  }

  .simulator-btn:link, .simulator-email-container-button {
    padding: 0.8rem 2rem;
  }

  .simulator-financial-fields {
    width: 100%;
  }

  .form-container-select {
    height: 4.2rem;
  }
}

@media only screen and (max-width: 24.6875em) {
  .section-simulator {
    overflow-x: hidden;
  }

  .tooltip-text {
    hyphens: auto;
    transform: translateX(-95%);
  }

  .simulator-container {
    height: 1400px;
  }
}

@media only screen and (max-width: 21.5625em) {
  .simulator-result-title--positive {
    display: block;
    margin-left: 0;
  }

  .simulator-result-title img {
    margin-bottom: 0;
  }

  .simulator-container {
    height: 1420px;
  }
}
