.my-account {
  display: flex;
  padding: 64px 100px 76px 100px;
  flex-direction: column;
  gap: 86px;
}
.my-account__title {
  color: #2e3f3b;
}
.my-account__content {
  display: flex;
  flex-direction: row;
  gap: 24px;
  width: 100%;
}
.my-account__content__tabs {
  display: flex;
  flex-direction: column;
  gap: 16px;
  overflow-x: auto;
  width: 16.6%;
  min-width: 286px;
  flex-shrink: 0;
  align-items: flex-start;
}
.my-account__content__tabs__tab {
  padding-bottom: 0px;
  color: #696969;
  cursor: pointer;
  white-space: nowrap;
  position: relative;
  display: inline-flex;
  text-align: left;
  font-size: 20px;
  text-decoration: none;
}
.my-account__content__tabs__tab.active {
  color: #181a1b;
  border-bottom: 3px solid #69a3a8;
}
.my-account__content__tab-panels {
  margin-top: 0px;
  width: 83.4%;
  flex-grow: 1;
}
.my-account__tab-panel {
  display: none;
}
.my-account__tab-panel.active {
  display: block;
}

.my-account-panel {
  width: 832px;
}
.my-account-panel__form {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
}
.my-account-panel__form__row {
  display: flex;
  gap: 16px;
  width: 100%;
}
.my-account-panel__form__row__group {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.my-account-panel__form__row__group__label {
  color: #181a1b;
}
.my-account-panel__form__row__group__input {
  height: 58px;
  border: none;
  background-color: #f4f4f4;
  border-radius: 100px;
  padding: 16px;
  padding-right: 48px;
  font-weight: 500;
  font-size: 16px;
  line-height: 26px;
  color: #2e3f3b;
  width: 100%;
  transition: all 0.2s ease;
  position: relative;
  background-image: none;
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 24px 24px;
}
.my-account-panel__form__row__group__input:focus {
  outline: none;
  border: 1px solid #e0e0e0;
  background-color: #fbfbfb;
}
.my-account-panel__form__row__group__input:hover {
  border: 1px solid #696969;
  background-image: url("../icons/edit.svg");
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 24px 24px;
}
.my-account-panel__form__row__group__input[type=password]:hover {
  background-image: none;
}
.my-account-panel__form__row .zipcode {
  flex: auto;
  width: 245px;
}
.my-account-panel__form__submit {
  display: flex;
  align-self: flex-end;
}
.my-account-panel__form__submit button {
  width: 398px;
  height: 60px;
  font-size: 16px;
  font-weight: 500;
}

.medical-assment-panel {
  width: 880px;
  overflow-y: hidden;
  padding: 0 24px;
}
.medical-assment-panel__form {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
}
.medical-assment-panel__form__row {
  display: flex;
  gap: 16px;
  width: 100%;
}
.medical-assment-panel__form__row__group {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.medical-assment-panel__form__row__group select {
  background: url("data:image/svg+xml,%3Csvg%20width='16px'%20height='16px'%20viewBox='0%200%2016%2016'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3E%0A%3Cpath%20fill-rule='evenodd'%20clip-rule='evenodd'%20d='M3.99935%204.6665L7.99935%208.6665L11.9993%204.6665L13.3327%205.99984L7.99935%2011.3332L2.66602%205.99984L3.99935%204.6665Z'%20fill='%23555555'/%3E%0A%3C/svg%3E") no-repeat;
  background-position: calc(100% - 16px) center !important;
  -moz-appearance: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  padding-right: 2rem !important;
  background-color: #f4f4f4;
  border-radius: 100px;
  padding: 16px;
}
.medical-assment-panel__form__row__group__radioGroup {
  display: flex;
  gap: 16px;
  width: fit-content;
}
.medical-assment-panel__form__row__group__radioGroup label {
  display: flex;
  gap: 12px;
}
.medical-assment-panel__form__row__group__radioGroup input[type=radio] {
  color: #345144;
  accent-color: #345144;
  height: 20px;
  width: 20px;
}
.medical-assment-panel__form__row__group__label {
  color: #181a1b;
}
.medical-assment-panel__form__row__group__input {
  height: 58px;
  border: none;
  background-color: #f4f4f4;
  border-radius: 100px;
  padding: 16px;
  padding-right: 48px;
  font-weight: 500;
  font-size: 16px;
  line-height: 26px;
  color: #2e3f3b;
  width: 100%;
  transition: all 0.2s ease;
  position: relative;
  background-image: none;
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 24px 24px;
}
.medical-assment-panel__form__row__group__input:focus {
  outline: none;
  border: 1px solid #e0e0e0;
  background-color: #fbfbfb;
}
.medical-assment-panel__form__row__group__input:hover {
  border: 1px solid #696969;
  background-image: url("../icons/edit.svg");
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 24px 24px;
}
.medical-assment-panel__form__row .zipcode {
  flex: auto;
  width: 245px;
}
.medical-assment-panel__form__submit {
  display: flex;
  align-self: flex-end;
}
.medical-assment-panel__form__submit button {
  width: 398px;
  height: 60px;
  font-size: 16px;
  font-weight: 500;
}

.registration {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 45px;
  justify-content: center;
  align-items: center;
  padding-top: 64px;
  padding-bottom: 200px;
  background-color: rgba(235, 248, 242, 0.2);
}
.registration__opImg {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 2;
  max-width: 100%;
  height: 100%;
  object-fit: cover;
}
.registration__stepper {
  z-index: 3;
  display: flex;
  align-items: center;
  width: 828px;
  gap: 19px;
  justify-content: center;
}
.registration h2 {
  color: #2e3f3b;
  z-index: 3;
}
.registration__form {
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 832px;
}
.registration__form__step {
  display: none;
}
.registration__form__step.active {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
}
.registration__form__step__header {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.registration__form__step__header span {
  color: #696969;
}
.registration__form__step__inputsRow {
  display: flex;
  flex-direction: row;
  gap: 16px;
}
.registration__form__step__inputBox {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}
.registration__form__step__inputBox input {
  width: 100%;
  height: 58px;
}
.registration__form__step__inputBox select {
  height: 58px;
}
.registration__form__step__inputBox span {
  color: #2e3f3b;
}
.registration__form__step__inputBox .error-email {
  color: #b22234;
  text-align: right;
}
.registration__form__step__inputBox select {
  background: url("data:image/svg+xml,%3Csvg%20width='16px'%20height='16px'%20viewBox='0%200%2016%2016'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3E%0A%3Cpath%20fill-rule='evenodd'%20clip-rule='evenodd'%20d='M3.99935%204.6665L7.99935%208.6665L11.9993%204.6665L13.3327%205.99984L7.99935%2011.3332L2.66602%205.99984L3.99935%204.6665Z'%20fill='%23555555'/%3E%0A%3C/svg%3E") no-repeat;
  background-position: calc(100% - 16px) center !important;
  -moz-appearance: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  padding-right: 2rem !important;
  background-color: #ffffff;
}
.registration__form__step__inputBox__radioGroup {
  display: flex;
  gap: 16px;
  width: fit-content;
}
.registration__form__step__inputBox__radioGroup label {
  display: flex;
  gap: 12px;
}
.registration__form__step__inputBox__radioGroup input[type=radio] {
  color: #345144;
  accent-color: #345144;
  height: 20px;
  width: 20px;
}
.registration__form__step p {
  text-align: left;
}
.registration__form__step__checkbox {
  display: flex;
  align-items: center;
  gap: 32px;
  margin-top: 8px;
}
.registration__form__step__checkbox input[type=checkbox] {
  accent-color: #3f7756;
  width: 50px;
  height: 50px;
  cursor: pointer;
  border-radius: 6px;
}
.registration__form__step__checkbox label {
  color: #2e3f3b;
}
.registration__form__step__checkbox label a {
  color: #2e3f3b;
  text-decoration: underline;
}
.registration__form__step__buttons {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
.registration__form__step__buttons .next-step {
  width: 263px;
}
.registration__form__step__buttons__rightSide {
  display: flex;
  gap: 12px;
}
.registration__form__step__buttons__rightSide .next-step,
.registration__form__step__buttons__rightSide .prev-step,
.registration__form__step__buttons__rightSide .finish-step {
  width: 142px;
}
.registration__form__step__buttons button {
  height: 60px;
  width: 336px;
}

.stepper-item {
  background-color: #ebf8f2;
  border: 1px solid #69a3a8;
  color: #2e3f3b;
  font-size: 16px;
  font-weight: 600;
  border-radius: 50px;
  padding: 12px 16px;
  width: fit-content;
  height: 60px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-grow: 1;
  justify-content: center;
}

.stepper-item.active {
  color: #ffffff;
  background-color: #2e3f3b;
  border: 1px solid #69a3a8;
}

.stepper-item.finished {
  color: #ffffff;
  background-color: #3f7756;
  border: 1px solid #3f7756;
}

.stepper-line {
  width: 32px;
  height: 1px;
  background-color: #d3d5de;
}

.stepper-item svg {
  display: none;
}

.stepper-item.finished svg {
  display: inline-block;
}

.register-textarea {
  border-radius: 25px;
  padding: 16px;
  gap: 10px;
  border: 1px solid #d3d5de;
  font-weight: 400;
  font-size: 16px;
  background: #ffffff;
  color: #696969;
  resize: none;
}
.register-textarea::placeholder {
  color: #696969;
  font-weight: 400;
  font-size: 16px;
}
.register-textarea:focus {
  outline: none;
  box-shadow: none;
  border-color: #2e3f3b;
}

.buttons-step2 {
  margin-top: 21px;
}

.signin {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 124px 100px;
  gap: 24px;
  background-color: #ebf8f2;
}
.signin__form {
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: 40px;
  width: 832px;
}
.signin__form__inputs {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.signin__form__inputs__checkboxRow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
}
.signin__form__inputs__checkboxRow__checkbox {
  display: flex;
  align-items: center;
  gap: 9px;
  color: #696969;
}
.signin__form__inputs__checkboxRow a {
  color: #3f7756;
  text-decoration: underline;
}
.signin__form__inputs__inputBox {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}
.signin__form__inputs__inputBox input {
  width: 100%;
  height: 58px;
}
.signin__form__inputs__inputBox span {
  color: #2e3f3b;
}
.signin__form__inputs__inputBox p {
  color: #b22234;
  text-align: right;
}
.signin__form__linkBox {
  text-align: center;
  color: #2e3f3b;
}
.signin__form__linkBox a {
  color: #3f7756;
}
.signin__form button {
  height: 60px;
}

.login {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 40px;
  justify-content: center;
  align-items: center;
  padding-top: 139px;
  padding-bottom: 200px;
  background-color: rgba(235, 248, 242, 0.2);
}
.login__opImg {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 2;
  max-width: 100%;
  height: 100%;
  object-fit: cover;
}
.login h2 {
  color: #2e3f3b;
  z-index: 3;
}
.login__form {
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: 40px;
  width: 770px;
  padding-left: 86px;
  padding-right: 86px;
  margin-top: 30px;
}
.login__form__inputs {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.login__form__inputs__checkbox {
  display: flex;
  align-items: center;
  gap: 9px;
  color: #696969;
}
.login__form__inputs__inputBox {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}
.login__form__inputs__inputBox input {
  width: 100%;
}
.login__form__inputs__inputBox span {
  color: #2e3f3b;
}
.login__form__inputs__inputBox p {
  color: #b22234;
  text-align: right;
}
.login__form__linkBox {
  text-align: center;
  color: #2e3f3b;
}
.login__form__linkBox a {
  color: #3f7756;
}
.login__form button {
  height: 60px;
}

.login-input {
  height: 69px;
  border-radius: 50px;
  padding: 16px;
  gap: 10px;
  border: 1px solid #d3d5de;
  font-weight: 400;
  font-size: 16px;
  background: #ffffff;
  color: #696969;
}
.login-input::placeholder {
  color: #696969;
  font-weight: 400;
  font-size: 16px;
}
.login-input:focus {
  outline: none;
  box-shadow: none;
  border-color: #2e3f3b;
}

.input-error {
  border: 1px solid #f55065 !important;
}

/* ========================================
   RESPONSIVE: ACCOUNT & REGISTRATION
   ======================================== */

@media (max-width: 1024px) {
  .my-account {
    padding: 60px 60px 76px 60px;
  }

  .my-account-panel {
    width: 100%;
  }

  .medical-assment-panel {
    width: 100%;
  }

  .registration__stepper {
    width: 100%;
    max-width: 828px;
  }

  .registration__form {
    width: 100%;
    max-width: 832px;
    padding: 0 20px;
  }

  .signin {
    padding: 100px 60px;
  }

  .signin__form {
    width: 100%;
    max-width: 832px;
  }

  .login__form {
    width: 100%;
    max-width: 770px;
  }
}

@media (max-width: 768px) {
  .my-account {
    padding: 40px 20px;
    gap: 40px;
  }

  .my-account__content {
    flex-direction: column;
  }

  .my-account__content__tabs {
    width: 100%;
    min-width: auto;
    flex-direction: row;
    overflow-x: auto;
    gap: 24px;
  }

  .my-account__content__tabs__tab {
    white-space: nowrap;
  }

  .my-account__content__tab-panels {
    width: 100%;
  }

  .my-account-panel {
    width: 100%;
  }

  .my-account-panel__form__row {
    flex-direction: column;
  }

  .my-account-panel__form__row .zipcode {
    width: 100%;
  }

  .my-account-panel__form__submit {
    align-self: stretch;
  }

  .my-account-panel__form__submit button {
    width: 100%;
  }

  .medical-assment-panel {
    width: 100%;
    padding: 0;
  }

  .medical-assment-panel__form__row {
    flex-direction: column;
  }

  .medical-assment-panel__form__row .zipcode {
    width: 100%;
  }

  .medical-assment-panel__form__submit {
    align-self: stretch;
  }

  .medical-assment-panel__form__submit button {
    width: 100%;
  }

  .registration {
    padding: 40px 20px 100px;
    gap: 32px;
  }

  .registration__opImg {
    display: none;
  }

  .registration__stepper {
    width: 100%;
    flex-wrap: wrap;
    gap: 12px;
  }

  .registration__stepper .stepper-item-text {
    display: none;
  }

  .registration__stepper .stepper-item.active .stepper-item-text {
    display: block;
  }

  .stepper-item {
    font-size: 14px;
    padding: 10px 12px;
    height: auto;
    min-height: 50px;
  }

  .stepper-line {
    display: none;
  }

  .registration__form {
    width: 100%;
    padding: 0;
  }

  .registration__form__step__inputsRow {
    flex-direction: column;
  }

  .registration__form__step__checkbox {
    gap: 16px;
  }

  .registration__form__step__checkbox input[type=checkbox] {
    width: 30px;
    height: 30px;
    flex-shrink: 0;
  }

  .registration__form__step__buttons {
    flex-direction: column;
    gap: 12px;
  }

  .registration__form__step__buttons .next-step {
    width: 100%;
  }

  .registration__form__step__buttons__rightSide {
    width: 100%;
    flex-direction: column;
  }

  .registration__form__step__buttons__rightSide .next-step,
  .registration__form__step__buttons__rightSide .prev-step,
  .registration__form__step__buttons__rightSide .finish-step {
    width: 100%;
  }

  .registration__form__step__buttons button {
    width: 100%;
  }

  .signin {
    padding: 60px 20px;
  }

  .signin__form {
    width: 100%;
  }

  .signin__form__inputs__checkboxRow {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .login {
    padding: 60px 20px 100px;
  }

  .login__opImg {
    display: none;
  }

  .login__form {
    width: 100%;
    padding: 0;
  }
}
