.form {
  margin: 50px 0;

  &.red {
    input[type="text"]:not(:read-only), input[type="email"]:not(:read-only), input[type="tel"]:not(:read-only), input[type="date"]:not(:read-only), input[type="datetime-local"]:not(:read-only), input[type="number"]:not(:read-only), input[type="url"]:not(:read-only), select:not(:read-only) {
      border-bottom: 1px solid var(--color-red);
    }

    textarea:not(:read-only) {
      border: 1px solid var(--color-red);
    }
  }

  label {
    display: block;
    font-weight: var(--font-weight-bold);
    margin-bottom: 10px;
  }

  input[type="text"]:not(:read-only), input[type="email"]:not(:read-only), input[type="tel"]:not(:read-only), input[type="date"]:not(:read-only), input[type="datetime-local"]:not(:read-only), input[type="number"]:not(:read-only), input[type="url"]:not(:read-only), select:not(:read-only) {
    border: none;
    border-bottom: 1px solid var(--color-primary-light);
    padding: 10px 0;
    width: 100%;
    outline: none;
    height: 44px;

    &:focus {
      border-bottom: 1px solid var(--color-primary);
    }
  }

  input[type="checkbox"] + label, input[type="radio"] + label {
    display: inline;
    font-weight: var(--font-weight-regular);
  }

  textarea:not(:read-only) {
    width: 100%;
    border: 1px solid var(--color-primary-light);
    border-radius: 5px;
    min-height: 110px;
    padding: 10px 15px;
    outline: none;

    &:focus {
      border: 1px solid var(--color-primary);
    }
  }

  .form-radio-group {
    display: flex;
    gap: 20px;
  }

  input[type="text"]:read-only, input[type="email"]:read-only, input[type="tel"]:read-only, input[type="date"]:read-only, input[type="datetime-local"]:read-only, textarea:read-only, input[type="number"]:read-only, input[type="url"]:read-only, select:read-only {
    border: none;
    display: block;
    padding: 0;
    margin: 0;
    width: 100%;
    resize: none;
    outline: none;
    cursor: auto;
  }

  .form-control {
    margin-bottom: 30px;
  }

  label[required="required"] {
    &:after {
      content: ' *';
    }
  }

  .form-field {
    margin-bottom: 40px;
  }
}


